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| ntroduction 


*A purpose and a target reader of this document 

This document describes the mechanisms of MB86290 Series Graphics Driver (the “Graphics Driver”) and 
application interfaces. 

This document is written for an engineer developing a graphics application using the “Graphics Driver”. 

A description of this document has premised the reader who has understood specification of MB86290 Series 
Graphics Controller (the “Graphics Controller”) and technology about graphics. 


If needed refer to the specification of Graphics Controller, or graphics-related books. 


*Graphics-related technology which will be the requisite for an understanding of this document 
Device coordinate system, object coordinate system, coordinate transformation, conversion matrix, clipping, 
polygon, shading, Z-buffer method, shade surface elimination, texture mapping, tilling, anti-aliasing, alpha 


blending, chrome-key composition, palette color, etc. 


*Specifications of the “Graphics Controller” 
For hardware specifications of the “Graphics Controller” and programming, refer to the following documents. 
- Graphics Controller Specifications 


- Application Note 


These documents are prepared for every “Graphics Controller”. 
Each “Graphics Controller” and document names are described in the table 1. 


Table 1. List of documents 


Graphics Controller Document title 
MB86290A MB86290A Graphics Controller Hardware Specifications 
Cremson Application Note 
MB86291/86291S MB86291 <SCARLET>Graphics Controller Specifications 


MB86291 <SCARLET>Application Note 
12C Interface Specification 


MB86291A MB86291A <SCARLET2>Graphics Controller Specifications 
MB86291 <SCARLET>Application Note 
MB86292/86292S MB86292 <ORCHID>Graphics Controller Specifications 


MB86292 <ORCHID>Application Note 

12C Interface Specification 

MB86293 MB86293 <CORAL-LQ>Graphics Controller Specifications 
M B86294/86294S MB86294 <CORAL-LB>Graphics Controller Specifications 
12C Interface Specification 


A specific “Graphics Controller” group may be shown as follows in this document. 

MB86291 or later : MB86291/86291S/86291A/86292/86292S/86293/86294/86294S Graphics Controller 
MB86291/86292 :MB86291/86291S/86291A/86292/86292S Graphics Controller 

MB86293 or later : MB86293/86294/86294S Graphics Controller or later 
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1 MB86290 Series Graphics Driver Overview 


This section describes abstract of the MB86290 Series Graphics Driver. 


The MB86290 Series Graphics Driver (the “Graphics Driver”) is a set of commands to assist 
graphics application programs utilizing the MB86290 Series Graphics Controller (the “Graphics 
Controller”). Each command to use the “Graphics Driver” from a graphics application program is 
called driver command. Abstract of the “Graphics Driver” is shown by figure 1.1. 

By using this Graphics Driver, graphics application programs can be made without concerning the 
code to access to hardware registers and management of Display List (refer to “2.1 Rendering 


Scheme”). 


Graphics Application Program 


C language interface 


Initializing Drawing etc 
command command 


Driver command 


MB86290 Series Graphics Driver 


Display List / Register access 


MB86290 Series Graphics Controller 


Figure 1.1 Overview of the “Graphics Driver” 
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2 Operation of MB86290 Series Graphics Driver 


This section describes rendering scheme by the “Graphics Driver”. 


2.1 Rendering Scheme 


Drawing operation of the “Graphics Controller” is started by sending respective command and it’s 
parameters. To draw one object, multiple commands need to be sent. Typically a bunch of commands 
to be required to draw one object are set together and transferred consecutively in effective ways such 
as DMA transfer or transfer of Local Display List. This bunch of commands is called Display List. 

Rendering scheme is shown in the figure 2.1. The drawing function of the “Graphics Driver” once 
stores the generated Display List in Display List buffer (refer to "2.2 Management of Display List") in 
order to transmit a Display List collectively by DMA etc (1). Then, transferring to the “Graphics 


Controller” is started with Display List transferring command (2). 


Graphics Application Program 


Display List buffer 


Display List 


Drawing Display List 
command transfer command 


MB86290 Series Graphics Driver 


Trigger 


MB86290 Series 
Graphics Controller 


Prepared by application designer 


Figure 2.1 Rendering scheme 
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2.2 Management of Display List 


The “Graphics Driver” stores generated Display List to Display List buffer and manages them. The 
Display List buffer is a certain amount of memory area allocated on either the local memory (the 
graphics memory) of the “Graphics Controller” or the host CPU memory. Acquisition of this area is 
done by graphics application program. Created Display List is stored in the Display List buffer till 
either obvious transfer order of it is made by the application program or no more open space will be 
available in the Display List buffer. (The trigger timing of Display List transfer is referred to “2.3.2 
Trigger of a Display List transfer”). 

Display List buffer has the method of using the whole as one area, and the method of dividing two 
and using (refer to figure 2.2). 1 block configuration and 2 blocks configuration are described in the 


following. 


(1)1 block configuration 


In 1 block configuration, the whole Display List buffer is used as one area. If the Display List 
buffer is configured in 1 block, once the Display List transfer is started, following Display List 
creation cannot be started until current transfer operation will complete and the buffer will be 


open. 


(2)2 blocks configuration 

In 2 blocks configuration, each block is used alternatively. In 2 blocks configuration, when 1 
block is completely full of Display List, transfer is started. But prior to wait this transfer start, 
following Display List can be stored into the alternative block. 

The biggest advantage of this 2 blocks configuration is that the host CPU can create a new 
Display List while the “Graphics Controller” executes rendering operations according to the 
current Display List. To make this scheme, the Display List needs to be transferred to the 


“Graphics Controller” via DMA or transfer of Local Display List. 
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(1) 1 block configuration 


Main memory or graphics memory 


Display List 
buffer 


Explanatory notes 


(2) 2 blocks configuration 
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Figure 2.2 Configuration of Display List buffer 
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2.3 Transfer of Display List 


2.3.1. Methods of Display List transfer 


For the Display List transfer, the following three options are available. Depends on the target 


system configuration, each application designer should choose the most appropriate option: 


- DMA transfer 
- Transfer of Local Display List 


- Display List write by host CPU 


2.3.2 Trigger of Display List transfer 


Display List transfer is started by the following events: 

- GdcFlush command call 

- GdcVF lush command call 

- Not enough space available in the Display List buffer to fill the Display List to be 


generated at the execution of respective driver command 
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2.4 Sync Mode and Async Mode 


The “Graphics Driver” has two operation modes, Sync mode and Async mode. Default mode is async 


mode. Switching of Sync mode and Async mode is performed by the GdcE xecM ode command. 


(1)Async mode 

In Async mode, each driver command returns back to the application right after it’s set of 
Display List to the Display List buffer. Display List transfer is performed in the condition as 
described in “2.3.2 Trigger of Display List transfer”. In this mode, Display List creation by the 
“Graphics Driver”, Display List transfer to the “Graphics Controller” and rendering, and it’s 


execution work independently. 


(2)Sync mode 
In Sync mode, regardless the method of the Display List transfer, each driver command transfers 
it’s generated Display List to the “Graphics Controller” immediately, and returns back to the 
application after the completion of the “Graphics Controller” rendering operations according to the 


Display List. This mode is mainly used in the debug of graphics application programs. 
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2.5 System Dependent Commands 


The system dependents command is a command to process procedures such as DMA transfer that 
depends on a target system and a graphics application program in the “Graphics Driver”. The 
relationship between system dependent commands and the “Graphics Driver” is shown in the figure 
2.5. 

The system dependent commands must be designed by each application designer according to the 
command interface specified by the “Graphics Driver”. (the command interface of the system 
dependent commands is referred to “8. System Dependent Commands I nterface”.) 


The following procedures must be implemented in the system depend commands. 


(1) Acquisition of the mapping address of the “Graphics Controller” register areas 
Gets the address allocation information of the “Graphics Controller” register areas and feed 
these information back to the “Graphics Driver” to access to various registers of the 
“Graphics Controller”. 

(2) Setting of the Display List buffer 
Informs the address allocation and size of the Display List buffer created by the application 
program to the “Graphics Driver”. 


(3) Display List transfer 


Transfers Display List to the “Graphics Controller” according to method of “2.3.1 Methods of 


Display List transfer." 
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Figure 2.5 System dependent commands and relation with the “Graphics Driver” 
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3 For Application Program Development 


This section describes mandatory operations and reminders in the application program 
development utilizing the “Graphics Driver”. 


3.1 Mandatory Operations 


3.1.1. Header files 


The “Graphics Driver” is prepared the following header files to application designers. 

Whenever driver command is called, gdc.h must be included. Since the gdctypes.h is already 
included in the gdc.h, application designers do not need to include it directly. 

- gdc.h : Declaration of driver command prototype 


- gdctypes.h : Definition of the data type applied in the “Graphics Driver” 


3.1.2 Gets Display List buffer 


The Display List buffer must be acquired by the application program. The buffer size should be 
32byte boundary. When DMA is applied to transfer Display List, the address allocation of the buffer 
and the block size must be aware. The address allocation and the buffer size should be defined not to 
conflict any source address restrictions of the DMA controller (if any). 

When DMA is adopted, always the source address is the top address of each Display List buffer 
block (if the Display List buffer is configured in 2 blocks, DMA transfer source address of the 1st block 
is a top address of Display List buffer. And DMA transfer source address of the 2nd block is “top 
address+1/2 byte count of the total Display List buffer). 


3.1.3. Creates system dependent commands 


The system dependent commands should be designed according to the command interface specified 


in “8. System Dependent Commands”. 
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3.2 Reminder 


3.2.1. Prohibition of re-entrant 


The “Graphics Driver” is not supported to reentrant. NOT to call the “Graphics Driver” from 
multiple tasks. If multiple tasks call the “Graphics Driver” simultaneously, these calling conventions 
must be managed exclusively, and avoid driver command call from one task before the completion of 


the driver command operation called by the other task. 
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4 Driver Commands 


This section describes each “Graphics Controller” can use any driver commands. 
Driver commands are shown in the following. 

- System control commands 

- Display commands 

- Color control commands 

- Cursor control commands 

- Drawing frame control commands 

- Primitive drawing control commands for device coordinates 

- Primitive drawing control commands for object coordinates 

- Drawing attribute control commands 

- Attribute control commands for object coordinates 

- Texture pattern management commands 

- Binary pattern drawing commands 

- Blt commands 

- Video capture control commands 

- 12C control commands 
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4.1 System Control Commands 


System control commands list is shown in the table 4.1. 


Table 4.1 System control commands list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| Gdclnitialize “Graphics Driver” initialization Y Y Y 
2 | GdcQueryVersion Version number check of the Y Y Y 
“Graphics Driver” 
3__| GdcSetl nternalClock Changes internal clock frequency N N Y 
4 | GdclnitDevice Initializes the “Graphics Controller” Y Y Y 
5 | GdcGeol nitialize Initialize geometry engine N X Y 
6 | GdcFlush Drawing by Display List (Asyno) Y Y Y 
7 | GdcVFlush Vertical blanking interval palling Y Y Y 
(Async) 
8 | GdcVerticalSync Adds vertical blanking interval Y Y Y 
command 
9 | Gdclnterrupt Interrupts request to host CPU 
10 | GdcE xecM ode Sets execution mode of Display List 
operation 
11 | GdcSetDMAMode Sets DMA mode Y Y Y 
12_| GdcGetFlFOStatus Gets Display List FIFO status Y Y Y 
13 | GdcGetFlFORemain Gets number of Display List FIFO Y Y Y 
open entries 
14 | GdcGetFlFOErrorStatus Gets Display List FIFO error status Y Y Y 
15 _ | GdcGetl nterruptStatus Gets interrupt status Y N N 
16 | GdcGeoGetl nterruptStatus Gets interrupt status N Y Y 
17 | GdcClearl nterruptStatus Clears interrupt status for Y N N 
MB86290A 
(*1)290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
18 | GdcGeoClear! nterruptStatus Clears interrupt status N Y Y 


for MB86291 or later 


19 | GdcSetl nterruptMask Sets interrupt mask for Y N N 
MB86290A 
20 | GdcGeoSetl nterruptM ask Sets interrupt mask for N ¥, Y 


MB86291 or later 


21 | GdcGeoGetF IF OStatus Gets geometry Display N Y Y 
List FIFO status 


22 | GdcGeoGetFlFORemain Gets number of geometry N Y Y 
Display List FIFO open 


entries 

23 | GdcSetMemoryM ode Sets memory interface Y Y Y 
mode 

24 | GdcSoftwareReset Resets by software 

25 | GdcGetErrCode Gets error code 

26 | GdcSetRegisterL ocation Changes address of 


registers location 


27 | GdcSetBurstMode Sets burst transfer mode N N Y 
of drawing 

28 | GdcQueryChip!lD Queries about chip 1D N N Y 

29 | GdcCancelDisplayList Cancels Display List Y Y Y 

30 | GdcGetPixelEngineStatus Gets pixel engine status Y N N 

31 | GdcGeoGetPixelEngineStatus Gets geometry pixel N Y Y 


engine status 


32 | GdcGetLocalDisplayListTransferStatus | Gets transfer of Local ¥ Y Y 


Display List status 


(*1)290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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4.2 Display Commands 


Display commands list is shown in the table 4.2. 


Table 4.2 Display commands list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcDispClock Sets display clock mode Y Y Y 
2 | GdcDispTiming Sets display timing parameters Y Y Y 
3 | GdcDispTimingWindow Sets W-layer display position Y Y Y 
4 | GdcDispDivideP os Sets border position of screen Y Y Y 
partition 
5 | GdcDispDimension Sets display frame attribute ¥ ¥ ¥ 
6 | GdcDispOn Asserts video signal output Y Y Y 
7__| GdcDispOff Negates video signal output Y Y Y 
8 | GdcDispLayerOn Asserts screen display Y Y Y 
9 | GdcDispLayerOff Negates screen display Y Y Y 
10 | GdcDispPos Sets display start position Y Y Y 
11 | GdcDispDoF lip Flips display bank Y Y Y 
12 | GdcOverlayPriorityMode Sets overlay display mode Y Y Y 
13 | GdcOverlayBlend Sets blend parameter for overlay Y af Y 
blend 
14 | GdcDispDisplayM ode Sets display mode N N Y 
15 | GdcDispDisplayL ayerM ode Sets layer display mode N N Y 
16 | GdcDispSetBackColor Sets background color N N Y 
17 | GdcDispSetL ayerWindow Sets position and size of the N N Y 
window mode layer 
18 | GdcLayerOverlayPriorityMode | Sets overlay display mode in every N N Y 
layer 
19 | GdcLayerOverlayBlend Sets blend mode in every layer N N Y 
20 | GdcDisplLayerOrder Sets layer display order N N Y 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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4.3 Color Control Commands 


Color control commands list is shown in the table 4.3. 


Table 4.3 Color control commands list 


No. Command name Function Graphics Controller (*1) 

290A 291/ 293/ 

292 294 
1_| GdcColorPalette Sets palette colors Y Y Y 
2 | GdcColorTransparent Sets transparent color Y Y Y 
3 _| GdcColorZeroM ode Sets color code 0 mode Y Y Y 
4 | GdcChromak eyM ode Sets Chroma-key mode Y Y Y 
5 | GdcColorK ey Sets key color for Chroma-key Y Y Y 
6 | GdcColorPaletteOffset | Sets of the color palette offset N N Y 


(*1)290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B 86293/86294/86294S 
Y : can be used 
N : can not be used 
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4.4 Cursor Control Commands 


Cursor control commands list is shown in the table 4.4. 


Table 4.4 Cursor control commands list 


No. Command name Function Graphics Controller (*1) 

290A 291/ 293/ 

292 294 
1 | GdcCursorAddress Sets cursor pattern memory Y Y Y 

address 
2 | GdcCursorPattern Sets cursor pattern Y Y Y 
3__| GdcCursorDisplay Controls cursor display Y Y Y 
4 | GdcCursorPos Sets cursor display position Y Y Y 
5 | GdcCursorPriority Sets cursor display priority mode Y Y Y 
6 | GdcCursorColorTransparent Sets cursor transparent color Y Y Y 
7__| GdcCursorColorZeroM ode Sets cursor color code 0 mode Y Y Y 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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4.5 Drawing Frame Control Commands 


Drawing frame control commands list is shown in the table 4.5. 


Table 4.5 Drawing frame control commands list 


No. Command name Function Graphics Controller (*1) 

290A 291/ 293/ 

292 294 
1_| GdcDrawDimension Sets drawing frame Y Y Y 
2 | GdcSetZPrecision Sets precision of Z value N N Y 
3__| GdcBufferCreateZ Sets Z buffer start address Y Y Y 
4 | GdcBufferCreateC Sets start address of polygon drawing Y Y Y 

flag buffer 
5 _| GdcBufferClearZ Clears Z buffer Y Y Y 
6 | GdcBufferClearC Clears polygon drawing flag buffer ¥ ¥ Y 
7 | GdcDrawClipFrame Sets drawing clip border Y Y Y 
8 | GdcSetAlphaMapBase Sets alpha map area start address N N Y 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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4.6 Primitive Drawing Control Commands for Device 


Coordinates 


Primitive drawing control commands for device coordinates list is shown in the table 4.6. 


Table 4.6 Primitive drawing control commands for device coordinates list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcPrimType Sets drawing procedure Y Y Y 
2 | GdcPrimEnd Completes drawing procedure Y Y Y 
3 | GdcTexCoord2D Sets coordinates of 2D texture Y Y Y 
(GDC_FIXED3z2 type) 
4 | GdcTexCoord2Df Sets coordinates of 2D texture Y Y Y 
(GDC_SFLOAT type) 
5 | GdcTexCoord2DNf Sets normalized coordinates of 2D texture Y Y Y 
(GDC_SFLOAT type) 
6 | GdcTexCoord3D Sets coordinates of 3D texture Y Y Y 
(GDC _FIXED32 type) 
7 | GdcTexCoord3Df Sets coordinates of 3D texture Y Y Y 
(GDC _SFLOAT type) 
8 | GdcTexCoord3DNf Sets normalized coordinates of 3D texture Y Y Y 
(GDC_SFLOAT type) 
9 | GdcDrawVertex2D Sets coordinates of 2D vertex Y Y Y 
(GDC _FIXED32 type) 
10 | GdcDrawVertex2Di Sets coordinates of 2D vertex (GDC_LONG Y Y Y 
type) 
11 | GdcDrawVertex3D Sets coordinates of 3D vertex Y Y Y 
(GDC _FIXED32 type) 
12 | GdcDrawVertex3Df Sets coordinates of 3D vertex Y Y Y 
(GDC_SFLOAT type) 
13_| GdcDrawPrimitive Draws multiple 3D triangles Y Y Y 


(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 


Y : can be used 


N : can not be used 
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4.7 Primitive Drawing Control Commands for Object 


Coordinates 


Primitive drawing control commands for object coordinates list is shown in the table 4.7. 


Table 4.7 Primitive drawing control commands for object coordinates list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcGeoPrimType Sets drawing procedure N Y Y 
2 | GdcGeoPrimEnd Completes drawing procedure N Y Y 
3 | GdcGeoDrawVertex2D Sets XY coordinates of vertex N Y Y 
(GDC_FIXED3z2 type) 
4 | GdcGeoDrawVertex2Df Sets XY coordinates of vertex N Y Y 
(GDC_SFLOAT type) 
5 | GdcGeoDrawVertex2Di Sets XY coordinates of vertex N Y Y 
(GDC_LONG type) 
6 | GdcGeoDrawVertex3D Sets XYZ coordinates of vertex N Y Y 
(GDC_FIXED32 type) 
7 | GdcGeoDrawVertex3Df Sets XYZ coordinates of vertex N Y Y 
(GDC _SFLOAT type) 
8 | GdcGeoDrawVertex3Di Sets XYZ coordinates of vertex N Y Y 
(GDC_LONG type) 
9 | GdcGeoT exCoord2DN Sets texture coordinates N Y Y 
(GDC_FIXED32 type) 
10 | GdcGeoT exCoord2DNf Sets texture coordinates N Y Y 
(GDC _SFLOAT type) 
11 | GdcVertexColor3f Sets color of vertex (GDC_SFLOAT N Y Y 
type) 
12 | GdcVertexColor32 Sets color of vertex (GDC_COLOR32 N Y Y 
type) 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 


Y : can be used 


N : can not be used 
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4.8 Drawing Attribute Control Commands 


Drawing attribute control commands list is shown in the table 4.8. 


Table 4.8 Drawing attribute control commands list 


No. Command name Function Graphics Controller (*1) 

290A 291/ 293/ 

292 294 
1_| GdcColor Sets vertex color/foreground color Y Y Y 
2 | GdcBackColor Sets background color Y Y Y 
3 | GdcClipMode Sets clipping mode Y Y Y 
4 | GdcSetAttrLine Sets line drawing attribute Y Y Y 
5 | GdcSetAttrSurf Sets surface drawing attribute Y Y Y 
6 | GdcSetAttrT exture Sets texture mapping attribute Y Y ae 
7 | GdcSetAttrBlt Sets BitBIt attribute Y Y Y 
8 | GdcSetAlpha Sets alpha blend ratio Y ¥ Y 
9 | GdcSetLinePattern Sets broken line pattern Y Y Y 
10 | GdcSetTextureBorder Sets texture border color Y Y Y 
11 | GdcSetRop Sets logical calculation mode Y Y Y 

(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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4.9 Attribute Control Commands for Object Coordinate 


Attribute control commands for object coordinate list is shown in the table 4.9. 


Table 4.9 Attribute control commands for object coordinate list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcGeoSetAttrMisc Sets miscellaneous attribute N Y Y 
2 | GdcGeoSetAttrLine Sets line drawing attribute for N Y Ne 
object coordinates 
3 | GdcGeoSetAttrSurf Sets surface drawing attribute N Y Y 
for object coordinates 
4 | GdcGeoLoadMatrix Sets matrix (GDC_FIXED32 N Y Y 
type) 
5 | GdcGeoL oadM atrixf Sets matrix (GDC_SFLOAT type) N 
6 | GdcGeoNdcDcViewportCoef Sets coefficients of NdcDc N 
transformation for xy 
(GDC _FIXED32 type) 
7 | GdcGeoNdcDcViewportCoeff Sets coefficients of NdcDc N Y Y 
transformation for xy 
(GDC _SFLOAT type) 
8 | GdcGeoNdcDcDepthCoef Sets coefficients of NdcDc N Y Y 
transformation for z 
(GDC_FIXED32 type) 
9 | GdcGeoNdcDcDepthCoeff Sets coefficients of NdcDc N Y Y 
transformation for z 
(GDC_SFLOAT type) 
10 | GdcGeoViewVolumexY Clip Sets view volume boundary for xy N Y Y 
(GDC_FIXED32 type) 
11 | GdcGeoViewVolumexY Clipf Sets view volume boundary for xy N Y Y 
(GDC_SFLOAT type) 
12 | GdcGeoViewVolumeZClip Sets view volume boundary for z N Y Y 
(GDC_FIXED32 type) 


(*1)290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
13 | GdcGeoViewVolumeZClipf Sets view volume boundary for z N Y Y 


(GDC _SFLOAT type) 


14 | GdcGeoViewVolumeWminClip Sets view volume boundary for w N Y Y 


(GDC_FIXED32 type) 


15 | GdcGeoViewVolumeWminClipf Sets view volume boundary for w N Y Y 


(GDC_SFLOAT type) 


16 | GdcGeoSetLogOutBase Sets top address for log output of N N Y 


device coordinate 


17 | GdcGeoSetL ogOutM ode Sets log output mode of the N N Y 


device coordinate 


18 | GdcGeoShadowXY Sets xy offset of shadow N N 


19 | GdcGeoOverlapZ Sets Z value of primitives (body / N N 
shadow / border / correction in 


top-left rule non-applicable mode) 


20 | GdcGeoShadowColor Sets color of shadow N N Y 
21 | GdcGeoShadowBackColor Sets background color of shadow N N Y 
22 | GdcGeoBorderColor Sets color of border N N Y 
23 | GdcGeoBorderBackColor Sets background color of border N N Y 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
Y : can be used 


N : can not be used 
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4.10 Texture Pattern Management Commands 


Texture pattern management commands list is shown in the table 4.10. 


Table 4.10 Texture pattern management commands list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcTextureM emoryM ode Sets texture memory mode Y Y Y 
2 | GdcTextureLoadI nt Loads texture/tile pattern to internal Y Y Y 
texture memory 
3 | GdcTextureL oadE xt Loads texture pattern to the Y Y Y 
graphics memory 
4 | GdcTextureLoadE xt8 Loads 8bpp texture pattern to the N N Y 
graphics memory 
5 | GdcTextureLoadE xt16 Loads 16bpp texture pattern to the Y Y Y 
graphics memory 
6 | GdcTextureLoadE xt24 Loads 24bpp texture pattern to the N N Y 
graphics memory 
7 | GdcTextureLoadI nt16F ast Loads 16bpp texture pattern to N N Y 
internal texture memory 
8 | GdcTextureL oadE xt16F ast Loads 16bpp texture pattern to the N N Y 
graphics memory 
9 | GdcTextureDimension Sets texture information Y Y 
10 | GdcBltTexture Loads BIt texture to internal texture 
memory for MB86290A 
11 | GdcGeoBIltT exture Loads BIt texture to internal texture N Y Y 
memory for MB86291 


(*1)290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 


Y : can be used 


N : can not be used 
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4.11 Binary Pattern Drawing Commands 


Binary pattern drawing commands list is shown in the table 4.11. 


Table 4.11 Binary pattern drawing commands list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcBitPatternDraw Draws binary pattern Y Y Y 
2_ | GdcBitPatternM ode Sets enlarge/shrink mode Y Y Y 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 


Y : can be used 


N : can not be used 


MB 86290 Series 
Graphics Driver Users Manual 
24 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


4.12 BLT Commands 


BIt commands list is shown in the table 4.12. 


Table 4.12 BIt commands list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1 | GdcBltCopy Copies BitBIt pattern within current Y Y Y 
drawing frame 
2 | GdcBItCopyAlt Copies BitBIt pattern between any Y Y Y 
drawing frame (Async) 
3 | GdcBItCopyAltSync Copies BitBIt pattern between any Y Y Y 
drawing frame (Sync) 
4 | GdcBltDraw Draws BitBIt pattern Y Y Y 
5 | GdcBItFill Fills BitBlt field Y 
6 | GdcBltColorTransparent | Sets transparent color of transparent 
BitBlt 
7 | GdcBItCopyAltAlpha Copies BitBIt pattern with alpha N N Y 
blending 
(*1)290A:M B86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 


Y : can be used 


N : can not be used 
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4.13 Video Capture Control Commands 


Video capture control commands list is shown in the table 4.13. 


Table 4.13 Video capture control commands list 


No. Command name Function Graphics Controller (*1) 
290A 291/ 293/ 
292 294 
1_| GdcCapSetVideoCaptureM ode Sets mode of video capture N Y Y 
2 | GdcCapGetE rrorStatus Gets error status of video N Y Y 
capture 
3 | GdcCapClearErrorStatus Clears error status of video N Y ¥. 
capture 
4 | GdcCapSetVideoCaptureB uffer Sets video capture buffer N Y 
5__| GdcCapSetl mageArea Sets range of image N Y 
6 | GdcCapSetDisplaySize Sets dimension of captured N Y (*2) 
image for scaling 
7 | GdcCapGetl mageAddress Gets address of captured N N Y (*2) 
image 
8 | GdcCapSetWindowMode Sets W(L1) layer mode N Y Y 
9 | GdcCapSetVideoCaptureScale Sets scale of video capture N Y Y (*3) 
10 | GdcCapSetAttrMisc Sets attribute of video capture N Y 
11 | GdcCapSetl nputDataCountNTSC Sets number of video capture N Y 
data for NTSC 
12 | GdcCapSetl nputDataCountPAL Sets number of video capture N Y Y 
data for PAL 
13 _ | GdcCapSetLPF Mode Sets low pass filter mode N Y Y 


(*1)290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
(*2)M B86294 can be used (MB86293 can not be used) 
(*3)M B86293 can be used (MB86294 can not be used) 


Y : can be used 


N : can not be used 
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4.14 ’?C Control Commands 


12C control commands list is shown in the table 4.14. 


Table 4.14 12C control commands list 


No. Command name Function Graphics Controller (*1) 

290A | 291/ 293/ 

292 294 
1_| Gdd 2CGetBusStatus Gets |?C bus status N y y 
2__| Gddl 2CSetBusControl Controls |2C bus N y y 
3__| Gdcl2CGetBusControlStatus _| Gets |12C bus control status N y y 
4 | Gdcl2CSetClock Sets |2C dock N y y 
5 | Gdd 2CGetClock N y y 
6 | Gdd2CSetData Sets transfer data N y y 
7 | Gdd 2CGetData Gets transfer data N y y 


(*1 


~~ 


290A:MB86290A, 291/292:M B86291/86291A/86291S/86292/86292S, 293/294:M B86293/86294/86294S 
y : These commands can be used only following Graphics Controllers. 

MB86291S,M B86292S, or MB86294S or later which supported video capture function. 
N : can not be used 
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5 Data Format 


This section describes the data types and data structures specified by “Graphics Driver”. 


5.1 Data Type 


Data types to define in the “Graphics Driver” is shown in the table 5.1. 


Table 5.1 Data type list 


Format Description 


GDC_FIXED32 32 bits signed fixed point 
(1 bits sign,15 bits integer and 16 bits fraction) 


GDC_FIXED_SCALE 16 bits unsigned fixed point for Capture Scale 
(5 bits integer and 11 bits fraction) 


GDC_SFLOAT 32 bits single precision float (IEEE 754 compliant) 
GDC ULONG 32 bits unsigned integer 

GDC_LONG 32 bits signed integer 

GDC _USHORT 16 bits unsigned integer 

GDC _ SHORT 16 bits signed integer 

GDC _UCHAR 8 bits signed integer 

GDC_COLOR32 32 bits unsigned integer (32 bits color format) 
GDC_COL32 32 bits unsigned integer (palette color format) 
GDC_COL16 16 bits unsigned integer (16 bits color format) 
GDC_COL8 8 bits unsigned integer (8 bits color format) 
GDC_LPPCOL32 Pointer for GDC_COL32 format data 
GDC_LPCOL24 Pointer for GDC_COLOR32 format data 
GDC_LPCOL16 Pointer for GDC_COL16 format data 
GDC_LPCOL8 Pointer for GDC_COL8 format data 
GDC_LPLONG Pointer for GDC_LONG format data 


GDC_LPBINIMAGE Pointer for 32 bits unsigned integer data (binary pattern data) 


GDC VERTEX GDC_SFLOAT format vertex data structure 
GDC_BOOL True/false(value of GDC_TRUE / GDC_FALSE) 


[Note] It is not used as a type of the return value of the driver 


command 
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5.2 Data Structure 


Data structures at to define in the “Graphics Driver” is shown in the following. 


5.2.1. GDC_FIXED32 [82 bits fixed point] 


A fixed point data with sign described in sign 1 bit, integer 15 bits, and fraction 16 bits. 


31 30 16 15 


S: Sign (1 bit) 
0:Positive number or zero 
1:Negative number 

1: Integer (15 bits) 

F: Fraction (16 bits) 


Figure 5.2.1 GDC_FIXED32 format 


5.2.2 GDC_FIXED_SCALE [Capture scale] 


A capture scale data described in integer 5 bits, fraction 11 bits. 
It used by the GdcCapSetVideoCaptureScale command. 


1: Integer (5 bits) 
F: Fraction (11 bits) 
Figure 5.2.2 GDC_FIXED_SCALE format 
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5.2.3 GDC COLOR32 [32 bits color] 


A color data described in 8 bits per R, G and B respectively. 
It used by the GdcVertexColor32 command. 


A:Alpha bit (8 bits) 

Sets blend ratio of vertex 
R,G,B: 

Color bit (8 bits) 


Figure 5.2.3 GDC_COLOR32 format 


5.2.4 GDC COL32 [Palette color] 


A color data described in 6 bits per R, G and B respectively. For C layer palette, bit 31 is an 
alpha bit. 


31 30 29 28 ef 26 25 24 23 22 21 20 19 18 17 16 


A 0 0 0 0 0 0 0 R 0 0 
1 14 #13 #12 ~ «11 10 9 8 7 6 5 4 3 2 1 0 
G 0 0 B 0 0 


A:Alpha bit (1 bit) 
When blend mode is available, sets mode of blend 
0:Blending 
1:Not blending 
R,G,B: 
Color bit (6 bits) 


Figure 5.2.4 GDC_COL32 format 
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5.2.5 GDC COL16 [16 bits color] 


A color data described in 5 bits per R, B and G respectively. When this color data format is 
applied to texture, bit 15 is used as an alpha bit. 


A R G B 
A:Alpha bit (1 bit) 


When blend mode is available, sets mode of blend or stencil processing 
0:Blending or stencil processing 
1:Not blending or stencil processing 
R,G,B: 
Color bit (5 bits) 


Figure 5.2.5 GDC_COL16 format 


5.2.6 GDC COL8 [8 bits color] 


A index code to refer to color palette in 8 bits. 


Index code 


Figure 5.2.6 GDC_COL8 format 
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5.2.7 GDC _VERTEX [GDC_SFLOAT format vertex data structure] 


GDC_VERTEX structure is shown in the table 5.2.7. 
A structure data is packed in vertex coordinates, texture coordinates and RGB value. 


It used by the GdcDrawPrimitive command. 


Table 5.2.7 GDC_VERTEX structure 


Type Parameter Description 
GDC_SFLOAT x x coordinates of vertex (for device coordinates) 
GDC_SFLOAT y y coordinates of vertex (for device coordinates) 
GDC_SFLOAT Zz z coordinates of vertex (for device coordinates) 
GDC _SFLOAT r r value of vertex color 
GDC_SFLOAT g g value of vertex color 
GDC_SFLOAT b b value of vertex color 
GDC_SFLOAT u u texture coordinates of vertex 
GDC_SFLOAT Vv v texture coordinates of vertex 
GDC_SFLOAT rw Reciprocal w texture coordinates of vertex 
long work Reserved 
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6 Driver Command Reference 


This section describes calling conventions interface and processing contents of driver commands. 


6.1 Explanatory notes 


Each item of a driver command reference is described as below. 


Format Prototype declaration of a command. 
Parameter Description of a parameter. 
The "default" in explanation expresses the value set up at the initialization of the 
“Graphics Driver”. 
Return value =Thereturn values and the description of them. 
Error code The error code and a name of an error when a command ends abnormally. 
When the command ends normally, the error code is not set. 
In this case the error code just before is held. 
The error code is got by the GdcGetErrCode command. 
This item is omitted if the command has no return values. 
In some commands errors don’t occur even if the commands have the return values. 
(At the present function, the command has no unusual end.) 


Description Description of the command. 
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6.2 System Control Commands 


6.2.1. Gdclnitialize [“Graphics driver” initialization] 


Format int Gdclnitialize(int gdc_type) 


Parameter gdc_type A type of the “Graphics Controller” 


GDC_TYPE_MB86290A_In case of using MB86290A 
GDC_TYPE_MB86291 In case of using MB86291/862915S 
GDC_TYPE_MB86291A In case of using MB86291A 
GDC_TYPE_MB86292 In case of using MB86292/86292S 
GDC_TYPE_MB86293 _ In caseof using MB86293 
GDC_TYPE_MB86294 In case of using MB86294/86294S 


Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_DL_BUF_ALLOC (Failure of Display List buffer acquisition) 


- GDC_ERR_DL_SIZE (Incorrect buffer size) 
- GDC_ERR_DL_NUM (Not appropriate block count) 
Description Initialize the “Graphics Driver”. 
This command precedes all driver commands, and call only once. 
If this command is called, the following system dependent commands will be called 
inside. 
- GdcSetDisplayListBuffer command 
- GdcGetH ostRegisterAddress command 
- GdcGetDispRegisterAddress command 
- GdcGetDrawRegisterAddress command 
For details about initialization processing of the “Graphics Driver”, refer to 
"initialize.c' file in sample directory. 


This command can be used by all “Graphics Controller”. 
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6.2.2 GdcQueryVersion [Version number check] 


Format void GdcQueryVersion (int *version, int *level) 
Parameter version Pointer to store version number 
level Pointer to store level number 


Return value None 
Description Indicates current version and level number of the “Graphics Driver”. 
Version number and level number are numerical value. 
For example, when the version number is 1, and the level number is 10, the following 
numbers are stored in each parameter. 
*version =1 
*level =10 


This command can be used by all “Graphics Controller”. 
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6.2.3. GdcSetinternalClock [Changes internal clock frequency] 


Format void GdcSetl nternalClock(GDC_ULONG geo_clock, GDC_ULONG other_clock) 


Parameter geo_clock Clock frequency for geometry engine 
GDC_CLOCK_166MHZ 166MHz 
GDC_CLOCK_133MHZ 133MHz 
GDC_CLOCK_100MHZ 100MHz 

other_clock Clock frequency for besides geometry engine 

GDC_CLOCK_133MHZ 133MHz 
GDC_CLOCK_100MHZ 100MHz 

Return value None 

Description Sets internal clock frequency. The combination of parameters are shown in the table 


6.2.3. 


Table 6.2.3 Internal clock frequency combinations 


geo _ clock 
166M Hz 133MHz 100M Hz 
other_clock 133MHz OK OK NG 
100MHz OK OK OK 
OK:Possible 


NG:I mpossible (not supported) 


Be sure to execute this command just after initialization by the Gdclnitialize 
command of the “Graphics Driver”. 

In order to steady status of the “Graphics Controller”, 200 microsecond intervals are 
necessary after setting internal dock frequency before executing the following 
procedures. 


This command is for MB86293 or later. 
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6.2.4 GdclnitDevice [Initializes the “Graphics Controller’’] 


Format 


Parameter 


Return value 


Description 


int GdclnitDevice (void) 


None 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


Initializes each register of the “Graphics Controller”. 
Be sure to execute this command once before calling other driver commands. 
However, be sure to execute the following commands before calling the Gddl nitDevice 
command. 

- Gdel nitialize command 

- GdcSetl nternalClock command 

- GdcSoftwareReset command 

- GdcSetRegisterLocation command 

- GdcSetM emoryM ode command 

- GdcSetBurstM ode command 


This command can be used by all “Graphics Controller”. 
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6.2.5 GdcGeolnitialize [Initialize geometry engine] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeol nitialize(void) 


None 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Initializes internal resources in the geometric engine. 
When using drawing commands for object coordinates, be sure to call this command 
after initializing the “Graphics Driver”. 
However, be sure to execute the following commands before calling the 
GdcGeol nitialize command. 

- Gdel nitialize command 

- GdcSetl nternalClock command 

- GdcSoftwareReset command 

- GdcSetRegisterLocation command 

- GdcSetM emoryM ode command 

- GdcSetBurstM ode command 

- Gdel nitDevice command 


This command is for MB86291 or later. 


6.2.6 GdcFlush [Drawing by Display List (Async)] 


Format 


Parameter 
Return value 


Description 


GDC_ULONG GdcFlush(void) 


None 

The transmitted number of byte 

Transfers a Display List in the Display List buffer to the “Graphics Controller”. If 
DMA is applied, this command is completed without waiting for the end of the list 
transfer. If CPU writes the Display List to the “Graphics Controller”, this command is 
completed after the end of the list transfer. 

The transmitted number of byte is set to return value. 


This command can be used by all “Graphics Controller”. 
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6.2.7 GdcVFlush [Vertical blanking interval palling (Async)] 


Format 


Parameter 


Return value 


Description 


Note 


GDC_ULONG GdcVFlush(void) 


None 

The transmitted number of byte 

Transfers a Display List after attaching a command for waiting Sync command (*1) to 
the end of it. 

When the Sync command is executed, the “Graphics Controller” synchronize the next 
operation with the vertical blanking interval. By means of this function, disorder of 
display caused by flipping can be avoided when flipping of drawing frame (the 
GdcDispDoF lip command). 

Similar to the GdcFlush command, this command does not wait for the completion of 
MB86290 Series’ all Display List operations. Therefore, the completion of the Sync 
command is not guaranteed after returning from this command. 

In order to detect the completion of the Sync command, use an interrupt for 
termination of drawing and so on. The interrupt can be issued by executing 
Gddl nterrupt before this GdcVFlush command. 

The transmitted number of byte is set to return value. 


This command can be used by all “Graphics Controller”. 


(*1) Sync command: It waits for drawing processing of the “Graphics Controller” until 
a vertical blanking interval period comes. 

This command dose not guarantee the punctual synchronous ness with the vertical 

blanking interval. In order to detect the punctual vertical blanking interval, use 


VSYNC interrupt. 


6.2.8 GdcVerticalSync [Adds vertical blanking interval command] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcVerticalSync(void) 


None 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Attaches a command for waiting VSYNC (Sync command ) to the end of a Display 
List. 

Transmission of a Display List is not performed. 


This command can be used by all “Graphics Controller”. 
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6.2.9 Gdclinterrupt [Interrupt request to host CPU] 


Format int Gdclnterrupt(void) 
Parameter None 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Generates an interrupt request. When the “Graphics Driver” works in sync mode, an 


interrupt request is generated immediately after the execution of this command. In 
async mode, a command to generate an interrupt request is put in a Display List. 


This command can be used by all “Graphics Controller”. 


6.2.10 GdcExecMode [Sets execution mode] 


Format void GdcE xecMode (GDC_UCHAR sync) 

Parameter sync Sync/Async mode selection 
GDC_EXECMODE_SYNC Sync mode 
GDC_EXECMODE_ASYNC Async mode 


Return value None 
Description Sets operation mode of the Display List execution. 


This command can be used by all “Graphics Controller”. 


MB 86290 Series 
Graphics Driver Users Manual 
40 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.2.11 GdcSetDMAMode [Sets DMA mode] 


Format int GdcSetDMAM ode(int tran_unit, int dma_request, int address_mode, 
int ack_mode) 
Parameter tran_unit Unit of DMA transfer 
GDC_DMA_TRANUNIT_4 4 byte 
GDC_DMA_TRANUNIT_32 32 byte 


dma_request DMA request 
GDC_DMA_REQUEST_NEGATE 
During transferring, when the “Graphics Controller” cannot 
receive data, DMA request is invalid (negate), and if it will be 


in the state where data is receivable, it will be valid (assert) 


GDC_DMA_REQUEST_NO_ NEGATE 
Not negate while DMA is transferring Display List 
address mode Address mode of external DMA request 
GDC_DMA_ADDRMODE_DUAL Dual address mode 
GDC_DMA_ADDRMODE_SINGLE _ Single address mode 
ack_mode ACK mode 
GDC_DMA_ACKMODE Uses ACK 
(detect DMA request at 
a low level signal) 
GDC_DMA_ NO _ACKMODE Not use ACK 
(detect DMA request at 


an edge) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_PARAMETER(Invalid parameter is specified) 


Description Sets DMA transfer mode to DSU (DMA Set Up) register. 
This command can be used by all “Graphics Controller”. 
However, “ack_mode” is available only for the MB86293 or later. 
In case of MB86290A/291/292, sets GDC_DMA_ACKMODE (uses ACK) to 


“ack_mode”. 
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6.2.12 GdcGetFlFOStatus [Gets Display List FIFO status] 


Format GDC_ULONG GdcGetFIF OStatus(void) 


Parameter None 


Return value —_ Display List FIFO status (IFSR register value) in the following format: 


bit 31 --- 2 1 0 
0 --- x x x 
bit 0: Valid data exists in Display List FIFO =0 
Valid data not exists in Display List FIFO =1 
bit1: Display List FIFO is full =0 
Display List FIFO is not full =1 
bit 2: Morethan half entries of Display List FIFO are empty =0 


More than half entries of Display List FIFO arenot empty =1 
All other bits:0 


Figure 6.2.12 Display List FIFO status 


Description Reads IFSR (Input FIFO Status Register) and returns current Display List FIFO 
status. 


This command can be used by all “Graphics Controller”. 


6.2.13 GdcGetFlFORemain [Gets number of Display List FIFO open entries] 


Format GDC_ULONG GdcGetFIFORemain(void) 


Parameter None 

Return value Number of open entries in the Display List FIFO 

Description Reads IFCNT (Input FIFO CouNTer) register and returns the number of open entries 
in the Display List FIFO. 


This command can be used by all “Graphics Controller”. 
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6.2.14 GdcGetFIFOErrorStatus [Gets Display List FIFO error status] 


Format 


Parameter 


Return value 


Description 


GDC_ULONG GdcGetFIFOErrorStatus(void) 


None 


Display List FIFO error status (IFSR register value) in the following format: 


bit 31 --- 2 1 0 
0 --- x x x 
bit 0: | Command error (type code is not normal) No=0, Yes=1 


bit 1: Packet error (command code is not normal) No=0, Yes=1 
bit 2: FIFO overflow No=0, Yes=1 
All other bits:0 


Figure 6.2.14 Display List FIFO error status 


Reads EST (Error Status Register) and returns Display List FIFO error status. 


This command can be used by all “Graphics Controller”. 
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6.2.15 GdcGetinterruptStatus [Gets interrupt status] 


Format GDC_UCHAR_  GdcGetl nterruptStatus (void) 


Parameter None 


Return value Interrupts status (IST register value) in the following format: 


bit 7 ae 4 3 2 1 0 


0 --- Xx Xx Xx x x 


bit 0: | Command execution error interrupt Yes=1, No=0 


bit 1: | Command complete interrupt Yes=l, No=-0 
bit 2: =. VSYNC interrupt Yes=l, No=0 
bit 3: Framesync interrupt Yes=l, No=0 
bit 4: | External sync error interrupt Yes=l, No=0 
All other bits:0 


Figure 6.2.15 Interrupt status 


Description Reads IST (Interrupt Status Register) and return interrupt status. 
This command is only for MB86290A. 
When the “Graphics Controller” is MB86291 or later, GdcGeoGetl nterruptStatus 


must be used. 
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6.2.16 GdcGeoGetinterruptStatus [Gets interrupt status for MB86291 or later] 


Format GDC_ULONG GdcGeoGetl nterruptStatus(void) 


Parameter None 


Return value — Interrupts status (IST register value) in the following format: 


bit31  --- 4 3 2 1 0 

0 --- x x x x x 
bitO: | Command execution error interrupt Yes =1, No =0 
bitl: | Command complete interrupt Yes =1, No=0 
bit2: § VSYNC interrupt Yes =1, No=0 
bit3: = Framesync interrupt Yes =1, No =0 
bit4: | External sync error interrupt Yes =1, No =0 
All other bits:1 


Figure 6.2.16 Interrupt status 


Description Reads IST (Interrupt Status Register) and return interrupt status. 
This command is for MB86291 or later. 
When the “Graphics Controller” is MB86290A, GdcGetl nterruptStatus must be used. 
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6.2.17 GdcClearinterruptStatus [Clears interrupt status for MB86290A] 


Format 


Parameter 


Return value 


Description 


void GdcClearlnterruptStatus (GDC_UCHAR clear) 


clear Clear pattern (shown below) 
bit 7 --- 4 3 2 1 0 
1 --- x x x x x 


bit 0: | Command execution error interrupt Clear=0, Hold=1 


bit 1: | Command complete interrupt Clear=0, Hold=1 
bit 2: VSYNC interrupt Clear=0, Hold=1 
bit 3: Framesyncinterrupt Clear=0, Hold=1 
bit 4: | External sync error interrupt Clear=0, Hold=1 
All other bits:1 


Figure 6.2.17 Clear pattern format 


None 

Clears the interrupt event indicated by 0-4 bits in ISR (Interrupt Status Register) by 
the clear pattern specified as above. To clear an interrupt event, respective bit in the 
clear pattern for that event is set to 0 and all other bits are set to 1. 

This command is only for MB86290A. 

When the “Graphics Controller” is MB86291 or later, the 


GdcGeoClearI nterruptStatus command must be used. 
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6.2.18 GdcGeoClearInterruptStatus [Clears interrupt status for MB86291 or later] 


Format 


Parameter 


Return value 


Return value 


Description 


void GdcGeoClearl nterruptStatus(GDC_ULONG clear) 


clear Clear pattern (shown below) 
bit31  --- 4 3 2 1 0 

fate he) oe Mle [te | ae 
bitO: | Command execution error interrupt Clear =0, 
bitl: | Command complete interrupt Clear =0, 
bit2: § VSYNC interrupt Clear =0, 
bit3: = Framesync interrupt Clear =0, 
bit4: | External sync error interrupt Clear =0, 
All other bits:1 

Figure 6.2.18 Clear pattern format 
None 


Clears a request of interrupt, indicated by IST (Interrupt STatus) register, with 


clear pattern. 


To clear an interrupt event, respective bit in the dear pattern for that event is set to 


0 and all other bits are set to 1. 


This command is for MB86291 or later. 


When the “Graphics Controller” is MB86290A, the GdcClearlnterruptStatus 


command must be used. 


Hold =1 
Hold =1 
Hold =1 
Hold =1 
Hold =1 
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6.2.19 GdcSetinterruptMask [Sets interrupt mask for MB86290A] 


Format 


Parameter 


Return value 


Description 


void GdcSetl nterruptMask (GDC_UCHAR mask) 


mask Mask pattern (shown below) 
bit 7 --- 4 3 1 0 
0 --- x x x x 
bit 0: © Command error interrupt Mask=1, Enable=0 
bit 1: | Command complete interrupt Mask=1, Enable=0 
bit 2: VSYNC interrupt Mask=1, Enable=0 
bit 3: Framesync interrupt Mask=1, Enable=0 
bit 4: | External sync error interrupt Mask=1, Enable=0 
All other bits:0 
Figure 6.2.19 Mask pattern format 
None 


Sets interrupt mask pattern to|MASK (Interrupt MASK) register to disable interrupt 


requests generated by the respective events. 


This command is only for MB86290A. 


When the “Graphics Controller” is MB86291 or later, the GdcGeoSetl nterruptM ask 


command must be used. 
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6.2.20 GdcGeoSetinterruptMask [Sets interrupt mask for MB86291 or later] 


Format void GdcGeoSetl nterruptMask(GDC_ULONG mask) 

Parameter mask Mask pattern (shown below) 
bit31  --- 4 3 2 1 0 

0 --- x x x x x 

bitO: | Command execution error interrupt Mask =0, Enable =1 
bitl: | Command complete interrupt Mask =0, Enable =1 
bit2: —§ VSYNC interrupt Mask =0, Enable =1 
bit3: Frame sync interrupt Mask =0, Enable =1 
bit4: | External sync error interrupt Mask =0, Enable =1 
All other bits:0 


Figure 6.2.20 Mask pattern format 


Return value None 

Description Sets interrupt mask pattern to IMASK(Interrupt MASK) to disable interrupt 
requests generated by the respective events. 
This command is for MB86291 or later. 
When the “Graphics Controller” is MB86290A, the GdcSetl nterruptM ask command 


must be used. 


MB 86290 Series 
Graphics Driver Users Manual 
49 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.2.21 GdcGeoGetFiFOStatus [Gets geometry Display List FIFO status] 


Format GDC_ULONG GdcGeoGetF IF OStatus(void) 


Parameter None 


Return value Geometry Display List FIFO status in the following format: 


bit 31 --- 2 1 0 
0 --- x x x 
bit 0: Valid data exists in geometry Display List FIFO =0 
Valid data not exists in geometry Display List FIFO =1 
bit 1: | Geometry Display List FIFO is full =0 
Geometry Display List FIFO is not full =1 
bit 2: Morethan half entries of geometry Display List FIFO are empty =0 


More than half entries of geometry Display List FIFO arenot empty =1 
All other bits:0 


Figure 6.2.21 Display List FIFO status 


Description Returns current geometry Display List FIFO status. 


This command is for MB86291 or later. 


6.2.22 GdcGeoGetFlFORemain [Gets number of geometry Display List FIFO 
open entries] 


Format GDC_ULONG GdcGeoGetF 1 FORemain(void) 


Parameter None 
Return value |= Number of open entries in the geometry Display List FIFO 
Description Returns the number of open entries in the geometry Display List FIFO. 


This command is for MB86291 or later. 
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6.2.23 GdcSetMemoryMode [Sets memory interface mode] 


Format 


Parameter 
Return value 


Description 


void GdcSetMemoryM ode (GDC_ULONG memorymode) 


memorymode Mode information of memory interface (MMR register set data) 
None 

Sets memorymode value to MMR (Memory I/F Mode Register) and defines the 
operation mode of memory interface. Detail of the memorymode is referred to the 
MB86290 Series hardware specifications. 


This command can be used by all “Graphics Controller”. 


6.2.24 GdcSoftwareReset [Resets by software] 


Format 


Parameter 
Return value 


Description 


void GdcSoftwareReset (void) 


None 

None 

Sets “1” to SRST (Software ReSet) register and execute software reset. 

In addition, cancels Display List stored in Display List buffer. 

In order to steady status of the “Graphics Controller”, 32 bus clock cycles intervals are 
necessary after software reset before executing the following procedures. 


This command can be used by all “Graphics Controller”. 
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6.2.25 GdcGetErrCode [Gets error code] 


Format int GdcGetErrCode (void) 
Parameter None 
Return value Error code 


Description 


Returns an error code when a driver command abnormally ends. Currently this 


command is applicable to Gddl nitialize command only. 


This command can be used by all “Graphics Controller”. 


Error code 
GDC_ERR_DL_BUF_ALLOC 
GDC_ERR_DL_SIZE 


GDC_ERR_DL_NUM 


GDC_ERR_DATA_TOO BIG 
GDC_ERR_INVALID_LAYER 
GDC_ERR_INVALID_BANK 
GDC_ERR_INVALID_COLOR_MODE 
GDC_ERR_INVALID_CURSOR_ NUMBER 
GDC_ERR_ILLEGAL_DIMENSION 
GDC_ERR_INVALID ATTRIBUTE 
GDC_ERR_INVALID PRIMITIVE 
GDC_ERR_CREMSON_OPEN_FAILED 
GDC_ERR_ILLEGAL_VERTEX_COUNT 
GDC_ERR_ILLEGAL_LINE_WIDTH 
GDC_ERR_NOT_READY 
GDC_ERR_INVALID_ PARAMETER 


Failure of Display List buffer acquisition 
Incorrect buffer size 

A Display List buffer size for 1 block is not a 
multiply of 32byte, or less than the minimum 
applicable size 

Not appropriate block count 

Block count is other than 1, 2 

Too large data 

Invalid layer is specified 

Invalid bank is specified 

Invalid color mode is specified 

Invalid cursor number is specified 

Illegal vertical/horizontal size of pattern data 
Invalid attribute is specified 

Invalid primitive is specified 

Fail to initialize “Graphics Controller” 

Illegal number of vertex 

Illegal width of line 

“Graphics Driver” is not initialized 


Invalid parameter is specified 
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6.2.26 GdcSetRegisterLocation [Changes address of registers location] 


Format void GdcSetRegisterLocation (GDC_ULONG locate) 


Parameter locate Register location 
GDC_REG _LOCATE_CENTER Center location 
GDC_REG_LOCATE_BOTTOM The last location 
Return value None 
Description In SH-3/SH-4 mode sets this parameter when changing the register location from 
center (Ox1fcO0000) to the last (Ox3fc0000). 
Execute this command after having called the following commands. 
Be sure to execute the following commands before calling the 
GdcSetRegisterLocation command. 
- Gdel nitialize command 
- GdcSetl nternalClock command 
- GdcSoftwareReset command 
In order to steady status of the “Graphics Controller”, 20 bus clock cycles intervals 
are necessary after changes address of register location before executing the 
following procedures. 


This command is for MB86293 or later. 


6.2.27 GdcSetBurstMode [Sets burst transfer mode of drawing] 


Format void GdcSetBurstM ode(GDC_ULONG mode) 
Parameter mode Burst transfer mode 
GDC_ENABLE Enable 
GDC_DISABLE Disable 


Return value None 
Description Sets burst transfer mode of drawing. 
If the bus occupation rate of drawing becomes high, all the 6 layers may not be 
displayed. 
In this case, sets burst transfer mode to disable. 
Be sure to execute the GdcSetM emoryM ode commands before calling this command. 


This command is for MB86293 or later. 
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6.2.28 GdcQueryChipID [Queries about chip ID] 


Format void GdcQueryChiplD (int *chip_no, int *version) 
Parameter chip_no Pointer to the area which stores chip number 
version Pointer to the area which stores chip version number 


Return value None 

Description Indicates chip number and chip version number. 
Chip number and chip version number are numerical value. 
For details about each number, refer to the hardware specification of the “Graphics 
Controller” of use. 


This command is for MB86293 or later. 


6.2.29 GdcCancelDisplayList [Cancels Display List] 


Format void GdcCancelDisplayList (void) 


Parameter None 
Return value None 
Description Cancels the Display List stored in the Display List buffer. 


This command can be used by all “Graphics Controller”. 
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6.2.30 GdcGetPixelEngineStatus [Gets pixel engine status] 


Format GDC_ULONG GdcGetPixelEngineStatus (void) 


Parameter None 


Return value Pixel engine status in the following format: 


bit 31 aie 2 1 0 


bit 1-0: Rendering is complete =00 
Rendering is executing =01 


All other bits: unsettled 


Figure 6.2.30 Pixel engine status 


Description Returns pixel engine status. 
This command is only for MB86290A. 
When the “Graphics Controller” is MB86291 or later, the GdcGeoGetPixelE ngineStatus 


command must be used. 
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6.2.31 GdcGeoGetPixelEngineStatus [Gets geometry pixel engine status] 


Format GDC_ULONG GdcGeoGetPixelE ngineStatus (void) 


Parameter None 


Return value Geometry pixel engine status in the following format: 


bit 31 aie 2 1 0 


bit 1-0: Rendering is complete =00 
Rendering is executing =01 


All other bits: unsettled 


Figure 6.2.31 Geometry pixel engine status 


Description Returns pixel engine status. 
This command is only for MB86291 or later. 
When the “Graphics Controller” is MB8629A, the GdcGetPixelEngineStatus command 


must be used. 


6.2.32 GdcGetLocalDisplayListTransferStatus [Gets Local Display List transfer 


status] 
Format GDC_ULONG GdcGetLocalDisplayListT ransferStatus (void) 
Parameter None 


Return value Transfer of Local Display List status in the following format: 


bit 31 seal 2 1 0 


0 nes 0 0 x 


bit 0: Transfer is complete =0 
Transfer is executing =1 


All other bits:0 


Figure 6.2.32 Local Display List transfer status 


Description Returns transfer of Local Display List status. 


” 


This command can be used by all “Graphics Controller”. 
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6.3 Display Commands 


6.3.1 GdcDispClock [Sets display clock mode] 


Format void GdcDispClock (GDC_ULONG mode) 


Parameter mode Sets display clock mode. This parameter is directly set to the correlated 
hardware DCM or DCEM register of the “Graphics Controller”. F or 
details of the DCM,DCEM register description, refer to the “Graphics 
Controller” hardware specification of use. 

Return value None 

Description Controls display clock and sync mode by setting parameters to Display Control Mode 

register. 
- Sets display sync mode 
- Sets external sync mode 
- Sets signal type 
- Sets dot clock frequency 
- Sets dot clock source 


This command can be used by all “Graphics Controller”. 


6.3.2 GdcDispTiming [Sets display timing parameters] 


Format void GdcDispTiming (GDC_USHORT htp, GDC_USHORT hsp, 
GDC_USHORT hsw, GDC_USHORT hdp, 
GDC_USHORT vtr, GDC_USHORT vsp, 
GDC_USHORT vsw, GDC_USHORT vdp) 


Parameter htp Total horizontal pixel count 
hsp Hsync pulse timing 
hsw Hsync pulse width 
hdp Horizontal display pixel count 
vtr Total vertical raster count 
vsp Vsync pulse timing 
VSW Vsync pulse width 
vdp Vertical display raster count 


Return value None 
Description Sets display window size and display timing parameters. 


This command can be used by all “Graphics Controller”. 
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6.3.3 GdcDispTimingWindow [Sets W-layer display position] 


Format void GdcDispTimingWindow (GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h) 


Parameter x x coordinate in the device coordinates 
y y coordinate in the device coordinates 
Ww Window width (pixel unit) 
h Window height (pixel unit) 


Return value None 
Description Sets display position of the W(Window) layer. 
x and y should specify the display position at the upper left of a window frame. 


This command can be used by all “Graphics Controller”. 


6.3.4 GdcDispDividePos [Sets border position of screen partition] 


Format void GdcDispDividePos (GDC_USHORT hab) 


Parameter hdb Horizontal pixel count of left window 

Return value None 

Description Sets the border of left/right layers when screen partition mode is applied. 
When the value 0 is set, 1 line of right window is displayed as well as the value 1 is 
set. 


This command can be used by all “Graphics Controller”. 
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6.3.5 GdcDispDimension [Sets display frame attribute] 


Format int GdcDispDimension (GDC_UCHAR layer, GDC_UCHAR enable, 
GDC_UCHAR cmode, GDC_UCHAR fmode, 
GDC_ULONG loa0, GDC_ULONG loal, 
GDC_USHORT Iw, GDC_USHORT Ih) 


Parameter layer Layer selection 


GDC_DISP_LAYER_C_ _C layer 
GDC_DISP_LAYER_W_ W layer 
GDC_DISP_LAYER_ML ML layer 
GDC_DISP_LAYER_MR MR layer 
GDC_DISP_LAYER_BL BL layer 
GDC_DISP_LAYER_BR BR layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_LO LOlayer 

GDC_DISP_LAYER L1 L1 layer 

GDC_DISP_LAYER L2 L2layer 

GDC_DISP_LAYER L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


enable Layer display enable/disable 
GDC_ENABLE Layer display enable 
GDC_DISABLE Layer display disable 
cmode Color mode selection 


GDC_24BPP_FORMAT 24 bits color mode (*1) 
GDC_16BPP_FORMAT 16 bits color mode 
GDC_8BPP_FORMAT _ 8bits color mode 


fmode Flipping mode selection 
GDC_FLIPMODE_0 Display Bank 0 


GDC_FLIPMODE_1 Display Bank 1 
GDC_FLIPMODE_AUTO Display both banks alternately 


loaO Base address of logical frame of bank 0 
loal Base address of logical frame of bank 1 
lw Logical frame width (pixel unit) 
Ih Logical frame height (pixel unit) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_LAYER (Invalid layer is specified) 


Description Sets attributes of logical frame independently for C, W, ML, MR, BL and BR. In B and 
M layer, if either L(Left) or R(Right) layer is enables, the other side layer is also 
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enabled automatically. For W layer, cmode, fmode, loal and Ih are not applied. 
When layer specification is W layer, each variable of cmode, fmode, and loal and Ih is 
not used. 
When the following macros are set to display or not to display layers, both ML and 
MR, both BL and BR layers are displayed simultaneously. 

-GDC_DISP_LAYER_ML 

-GDC_DISP_LAYER_MR 

-GDC_DISP_LAYER_BL 

-GDC_DISP_LAYER_BR 
When the following macros are set to display or not to display layers, layers can be 
displayed or not displayed individually. 

-GDC_DISP_LAYER_L2 

-GDC_DISP_LAYER_L3 

-GDC_DISP_LAYER_L4 

-GDC_DISP_LAYER_L5 


When the L5 layer is used as a blend coefficient layer, this layer must be displayed in 
8 bits color mode. 

In case of extend display mode, L4 and L5 layer are not available in 8 bits color mode. 
When the L5 layer is used as a blend coefficient layer, this layer must be displayed in 
8 bits color mode (except L5 layer is used as a blend coefficient layer). 


This command can be used by all “Graphics Controller”. 


(*1)The 24 bits color mode function is for MB86293 or later, and this mode can be 
used with the “Graphics Controller” supporting the 24 bits color mode option. 
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6.3.6 GdcDispOn [Asserts video signal output] 


Format 


Parameter 
Return value 


Description 


void GdcDispOn (void) 


None 

None 

Outputs video signals. 

Screen display is started at this command call, so this command must be called after 
all the rest display parameters are set. Nothing is displayed prior to this command 
call. 


This command can be used by all “Graphics Controller”. 


6.3.7 GdcDispOff [Negates video signal output] 


Format 


Parameter 
Return value 


Description 


void GdcDispOff (void) 


None 
None 
Disables screen display of video signals. 


This command can be used by all “Graphics Controller”. 
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6.3.8 GdcDispLayerOn [Asserts screen display] 


Format int GdcDispLayerOn (GDC_UCHAR layer) 


Parameter layer Layer selection 


GDC_DISP_LAYER_C_  C layer 
GDC_DISP_LAYER_W_ W layer 
GDC_DISP_LAYER_M_ M layer 
GDC_DISP_LAYER_B eB layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_LO LOlayer 

GDC_DISP_LAYER_L1 L1layer 

GDC_DISP_LAYER L2 L2layer 

GDC_DISP_LAYER L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_LAYER (Invalid layer is specified) 
Description Displays the layer specified by the layer parameter. 


When the following macros are set to display layers, both ML and MR, both BL and 
BR layers are displayed simultaneously. 

-GDC_DISP_LAYER_M 

-GDC_DISP_LAYER_B 
When the L5 layer is used as a blend coefficient layer, this layer must be displayed. 


This command can be used by all “Graphics Controller”. 
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6.3.9 GdcDispLayerOff [Negates screen display] 


Format int GdcDispLayerOff (GDC_UCHAR layer) 


Parameter layer Layer selection 


GDC_DISP_LAYER_C_  C layer 
GDC_DISP_LAYER_W_ W layer 
GDC_DISP_LAYER_M_ M layer 
GDC_DISP_LAYER_B eB layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_LO LOlayer 

GDC_DISP_LAYER_L1 L1layer 

GDC_DISP_LAYER L2 L2layer 

GDC_DISP_LAYER L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_LAYER (Invalid layer is specified) 


Description Stops the display of specified layer. 
When the following macros are set to not display layers, both ML and MR, both BL 
and BR layers are not displayed simultaneously. 
-GDC_DISP_LAYER_M 
-GDC_DISP_LAYER_B 


This command can be used by all “Graphics Controller”. 


MB 86290 Series 
Graphics Driver Users Manual 
63 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.3.10 GdcDispPos [Sets display start position] 


Format int GdcDispPos (GDC_UCHAR layer, GDC_UCHAR bank, 
GDC_USHORT dx, GDC_USHORT dy) 


Parameter layer Layer selection 


GDC_DISP_LAYER_C_  C layer 

GDC_DISP_LAYER_ML ML layer 
GDC_DISP_LAYER_MR MR layer 
GDC_DISP_LAYER_BL BL layer 
GDC_DISP_LAYER_BR BR layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_LO LOlayer 

GDC_DISP_LAYER L2 L2layer 

GDC_DISP_LAYER L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


bank Logical frame bank selection 


GDC_DISP_BANK_O Bank O 
GDC_DISP_BANK.1  Bank1 


dx x coordinates of display start position 
dy y coordinates of display start position 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_INVALID_LAYER (Invalid layer is specified) 


- GDC_ERR_INVALID_BANK (Invalid bank is specified) 

Description Sets the display start position by the distance from the base position of logical frame. 
After this command execution, it set as the target of display of the bank specified by 
“bank”. 


This command can be used by all “Graphics Controller”. 
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6.3.11 GdcDispDoFlip [Flips display bank] 


Format int GdcDispDoF lip (GDC_UCHAR layer, GDC_UCHAR bank) 


Parameter layer Layer selection 


GDC_DISP_LAYER_ML ML layer 
GDC_DISP_LAYER_MR MR layer 
GDC_DISP_LAYER_BL BL layer 
GDC_DISP_LAYER_BR BR layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_L2 L2layer 

GDC_DISP_LAYER L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


bank Logical frame bank selection 


GDC_DISP_BANK_O Banko 
GDC_DISP_BANK_1  Bank1 


Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_INVALID_LAYER (Invalid layer is specified) 


- GDC_ERR_INVALID_BANK (Invalid bank is specified) 
Description Switching displays (flipping). 


This command can be used by all “Graphics Controller”. 
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6.3.12 GdcOverlayPriorityMode [Sets overlay display mode] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcOverlayPriorityMode (GDC_UCHAR mode) 


mode C layer overlay mode 


GDC_OVERLAY_C_ PRIORITY Simple priority mode 


(default) 
GDC_OVERLAY_C_ BLEND Blend mode 
GDC_TRUE Complete 
GDC_FALSE Incomplete 
None 


Sets overlay display mode. When simple priority mode is selected, C layer is displayed 
at the top of all the layers all the time. When blend mode is selected, after displaying 
all the rest layers according to the priority order, C layer color is transparently 
blended with the rest layers. 


This command can be used by all “Graphics Controller”. 
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6.3.13 GdcOverlayBlend [Sets blend parameter for overlay blend] 


Format int GdcOverlayBlend (GDC_UCHAR select, GDC_UCHAR blend) 


Parameter enable Overlay blend selection 


GDC_BLEND RATIO _C Blend target is C layer color 
GDC_BLEND_RATIO_WMB Blend target is W/M/B layer color 


blend Blending ratio (only upper 4 bits are valid) 
Effective values are 0x00-Oxf0 
Return value GDC_TRUE Complete 
GDC_FALSE _ Incomplete 


Error code None 
Description Sets the blend coefficient to determine the C layer color when the overlay mode is 
blend mode. 


The followings are the meanings of blend coefficient and formula to determine the C 
layer color. 


[Blend coefficient] 


Blend Blend coefficient 
0x00 0 

0x10 1/16 

0x20 2/16 

0x30 3/16 

OxfO 15/16 


[Blend formula] 


- For GDC_BLEND_ RATIO C 


(C_layer_color * blend_coefficient) 


+(W/M/B_layer_compound_color * (1- blend_coefficient)) 


- For GDC_BLEND_RATIO_WMB 


(C_layer_color * (1- blend_coefficient)) 


+(W/M/B_layer_compound_color * blend_coefficient) 


” 


This command can be used by all “Graphics Controller”. 
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6.3.14 GdcDispDisplayMode [Sets display mode] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcDispDisplayM ode (GDC_UCHAR mode) 


Standard display mode 


(default) 


mode Display mode 
GDC_STANDARD_MODE 
GDC_OVERLAY_EXT_MODE 
GDC_WINDOW_MODE 
GDC_EXTEND_ MODE 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

None 


Sets display mode of all layers. 
This command is for MB86293 or later. 


Difference among these modes are shown in table 6.3.14. 


Table 6.3.14 Function list 


Extend overlay mode 
Window mode 
Extend display mode 


Function Extend display Window mode Extend overlay Standard display 
mode mode mode 
(Window mode + 
Extend overlay 
mode) 

Overlay 6 layer 6 layer 4 layer + 4 layer + 
right and left right and left 
division division 

Displaying window 6 layer 6 layer 1 layer 1 layer 

Displaying background} OK OK OK NG 

color 

Changes layer OK NG OK NG 

order 

Palette 4 2 4 2 

number 


Displayed images of extend display mode and standard display mode are shown in the figure 6.3.14 
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LO layer 


L5 layer 


(a)Extend display mode 
Figure 6.3.14 Displayed images of extend display mode and standard display mode 


L4 layer 


L2 layer 


LO,L2,L4 layer L1 layer L3,L5 layer 


L1 layer 


Background color 


(b)Standard display mode 


6.3.15 GdcDispDisplayLayerMode [Sets layer display mode] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcDispDisplayLayerM ode (GDC_UCHAR layer, GDC_ULONG mode) 


layer Layer selection 
GDC_DISP_LAYER_LO LO layer 
GDC_DISP_LAYER L1 L1 layer 
GDC_DISP_LAYER L2 L2 layer 
GDC_DISP_LAYER_L3 L3 layer 
GDC_DISP_LAYER_L4 L4 layer 
GDC_DISP_LAYER_L5 L5 layer 

mode Layer display mode 
GDC_STANDARD_MODE Standard display mode 

(default) 

GDC_OVERLAY_EXT_MODE Extend overlay mode 
GDC_WINDOW_MODE Window mode 
GDC_EXTEND_MODE Extend display mode 

GDC_TRUE Complete 

GDC_FALSE Incomplete 


GDC_ERR_INVALID_LAYER (Invalid layer is specified) 

Changes display mode by each layer. 

In extend display mode setting, window mode and an extend overlay mode can be set at 

the same time. GDC_EXTEND_MODE has the following meanings. 
GDC_EXTEND_MODE =GDC_WINDOW_MODE | GDC_OVERLAY_EXT_MODE 

When L5 layer is used as a blend coefficient layer, this layer must be set extend display 

mode, 

This command is for MB86293 or later. 
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6.3.16 GdcDispSetBackColor [Sets background color] 


Format int GdcDispSetBackColor (GDC_COLOR32 color) 
Parameter color 24 bits background color 
Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 


Error code None 
Description Sets background color. 


This command is for MB86293 or later. 


6.3.17 GdcDispSetLayerWindow [Sets position and size of the window mode 


layer] 
Format int GdcDispSetLayerWindow (GDC_UCHAR layer, 
GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h) 
Parameter layer Layer selection 
GDC_DISP_LAYER_LO LO layer 
GDC_DISP_LAYER L1 L1 layer 
GDC_DISP_LAYER L2 L2 layer 
GDC_DISP_LAYER L3 L3 layer 
GDC_DISP_LAYER_L4 L4 layer 
GDC_DISP_LAYER_L5 L5 layer 
x x coordinates in the device coordinates 
y y coordinates in the device coordinates 
Ww Window width (pixel unit) 
h Window height (pixel unit) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 


Error code GDC_ERR_INVALID_LAYER (Invalid layer is specified) 
Description Sets x and y position and width and height of window mode layer. 
Setting to L1 layer is also available by the GdcDispTimingWindow command. 


This command is for MB86293 or later. 
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6.3.18 GdcLaye 


Format 


Parameter 


Return value 


Error code 


Description 


D 1999-2003 


rOverlayPriorityMode [Sets overlay display mode in every layer] 


int GdcLayerOverlayPriorityMode (GDC_UCHAR layer, GDC_UCHAR mode) 


layer Layer select 
GDC_DISP_LAYER_LO LO layer 
GDC_DISP_LAYER L1 L1 layer 
GDC_DISP_LAYER L2 L2 layer 
GDC_DISP_LAYER L3 L3 layer 
GDC_DISP_LAYER_L4 L4 layer 
GDC_DISP_LAYER_L5 L5 layer 

mode Overlay mode 
GDC_OVERLAY_PRIORITY Overlay with transparent 

color (default) 

GDC_OVERLAY_BLEND Overlay with blend 

GDC_TRUE Complete 

GDC_FALSE Incomplete 


GDC_ERR_INVALID_LAYER (Invalid layer is specified) 

Sets overlay display mode by each layer. 

Setting of C layer by the GdcOverlayPriorityM ode command reflects on LO layer. 

On the contrary, setting to LO layer by this command refracts on C layer. 

When L5 layer is used as a blend coefficient layer, this layer is not target of overlaying 
by transparent color or blend. 


This command is for MB86293 or later. 
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6.3.19 GdcLayerOverlayBlend [Sets blend mode in every layer] 


Format int GdcLayerOverlayBlend (GDC_UCHAR layer, GDC_UCHAR select, 
GDC_UCHAR correct, GDC_UCHAR source, GDC_UCHAR blend) 


Parameter layer Layer selection 
GDC_DISP_LAYER_LO LO layer 
GDC_DISP_LAYER _L1 L1 layer 
GDC_DISP_LAYER L2 L2 layer 
GDC_DISP_LAYER_L3 L3 layer 
GDC_DISP_LAYER_L4 L4 layer 
GDC_DISP_LAYER_L5 L5 layer 
select Selects of blend calculating method 


GDC_BLEND_CURRENT_RATIO 
layer color * blend ratio +lower layer color 
*(1 - blend ratio) 
GDC_BLEND_ONE_MINUS CURRENT RATIO 
layer color * (1 - blend ratio) 
+lower layer color * blend ratio 


correct Correction by 1/256 value 
GDC_BLEND_NO CORRECT 
Uses the blend ratio 
GDC_BLEND_CORRECT 
When the blend ratio is not 0, add 1/256 
(When using the blend ratio of 100%) 


source Selects source data of the blend ratio 
GDC_BLEND_RATIO_CONSTANT 
Uses the fixed value as blend ratio specified by “blend” 
GDC_BLEND RATIO_L5 
Uses pixel value of L5 layer for the blend ratio 


blend Blend ratio coefficient 
(used when "source” is GDC_BLEND_RATIO_CONSTANT) 
Effective values are 0-255 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_LAYER (Invalid layer is specified) 
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Description 


Sets the blend mode when overlay priority mode is “overlay with blend 
(GDC_OVERLAY_BLEND)”. 

Setting by the GdcOverlayBlend command reflect on LO layer. 

“correct” and “source” are set to GDC_BLEND_NO_ CORRECT and 
GDC_BLEND_RATIO_CONSTANT respectively when the mode is set by the 
GdcOverlayBlend command. 

Setting of “source” is not valid when L5 layer is set. 

When the L5 layer is used as a blend coefficient layer, set L5 layer as extend display 
mode by the GdcDispDisplayLayerM ode command. 

When the L1 layer is capture mode and L5 layer is used as blend coefficient layer, L1 
layer is not blended correctly. 

This command is for MB86293 or later. 
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D 1999-2003 


6.3.20 GdcDispLayerOrder [Sets layer display order] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcDispLayerOrder(GDC_UCHAR layer0, GDC_UCHAR layer1, 


layerO 


layer1 


layer2 


layer3 


layer4 


layer5 


GDC_TRUE 
GDC_FALSE 


GDC_UCHAR layer2, GDC_UCHAR layer3, 
GDC_UCHAR layer4, GDC_UCHAR layer5) 


Selects top level layer 


GDC_DISP_LAYER_LO LO layer 
GDC_DISP_LAYER L1 L1 layer 
GDC_DISP_LAYER L2 L2 layer 
GDC_DISP_LAYER_L3 L3 layer 
GDC_DISP_LAYER_L4 L4 layer 
GDC_DISP_LAYER_L5 L5 layer 
GDC_NO_LAYER Not select layer 


Selects the second level layer (as for the value, the same in case of 
layer0) 

Selects the third level layer (as for the value, the same in case of 
layer0) 

Selects the fourth level layer (as for the value, the same in case of 
layer0) 

Selects the fifth level layer (as for the value, the same in case of 
layerO) 

Selects the sixth level layer (as for the value, the same in case of 
layer0) 

Complete 


Incomplete 


GDC_ERR_INVALID_LAYER (Invalid layer is specified) 


Sets display order of layers. Sets different layer in each level. 


The layer which was not selected is not displayed. 


When the L5 layer is used as a blend coefficient layer, this layer should not be selected. 


This command is for MB86293 or later. 
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6.4 Color Control Commands 


6.4.1 GdcColorPalette [Sets palette colors] 


Format int GdcColorPalette (GDC_UCHAR layer, GDC_UCHAR number, 
GDC_UCHAR size, GDC_LPPCOL3z2 I|pColor) 


Parameter layer layer palette selection 


GDC_C_LAYER_PALETTE _ Select C layer palette 
GDC_MB_LAYER_PALETTE Select MB layer palette 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_LO LAYER_PALETTE Select LO layer palette 

(same as C layer palette) 
GDC_L1LAYER_PALETTE Select L1 layer palette 

(Same as MB layer palette) 
GDC_L2 LAYER_PALETTE Select L2 layer palette 
GDC_L3_ LAYER_PALETTE Select L3 layer palette 


number Sets the head palette number 
size Sets the palette number 
I pColor Pointer to the color data 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_LAYER (Invalid layer is specified) 
Description Sets color index code to palette table. If size is set to “O”, all 256 entries of selected 


palette are set. 

Setting of palette is available without regard to display mode. 

However, L2,L3 layer palettes are available only in extend display mode(only in 
MB86293 or later). 


This command can be used by all “Graphics Controller”. 
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6.4.2 GdcColorTransparent [Sets transparent color] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcColorTransparent (GDC_UCHAR layer, GDC_COLOR32 color) 


layer Layer selection 
GDC_DISP_LAYER_C_ _C layer 
GDC_DISP_LAYER_ML ML layer 
GDC_DISP_LAYER_MR MR layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_LO LOlayer 

GDC_DISP_LAYER L1 L1 layer 

GDC_DISP_LAYER L2 L2layer 

GDC_DISP_LAYER_L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


color 
GDC_TRUE 
GDC_FALSE 
GDC_ERR_INVALID_LAYER (Invalid layer is specified) 


Transparent color code 
Complete 


Incomplete 


Sets transparent color code. In indirect color mode (in which color palette is applied), 
the lower 8 bits is used. 
LO, L2, L3 layers correspond to C, ML and MR layers. 
The following values are used by color mode of layer. 

- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command can be used by all “Graphics Controller”. 
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6.4.3. GdcColorZeroMode [Sets color code 0 mode] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcColorZeroM ode (GDC_UCHAR layer, GDC_UCHAR mode) 


layer Layer selection 


GDC_DISP_LAYER_C_ _C layer 
GDC_DISP_LAYER_ML ML layer 
GDC_DISP_LAYER_MR MR layer 


[When the “Graphics Controller” is MB86293 or later, 
following functions are available] 

GDC_DISP_LAYER_LO LOlayer 

GDC_DISP_LAYER L1 L1 layer 

GDC_DISP_LAYER L2 L2layer 

GDC_DISP_LAYER_L3 L3layer 

GDC_DISP_LAYER L4 L4layer 

GDC_DISP_LAYER_L5 LS layer 


mode Color 0 mode 


GDC_COLOR_NOTRANSPARENT Not transparent color 
GDC_COLOR_TRANSPARENT Transparent color 


GDC_TRUE Complete 
GDC_FALSE Incomplete 
GDC_ERR_INVALID_COLOR_MODE (Invalid color mode is specified) 
Select handling of color value 0 (palette number 0) from the following. 
- Not treaded as transparent color, and treated as normal color value (palette 
number) 
- Treated as transparent color 
LO, L2, L3 layers correspond to C, ML and MR layers. 


This command can be used by all “Graphics Controller”. 
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6.4.4 GdcChromaKeyMode [Sets Chroma-key mode] 


Format int GdcChromaK eyMode (GDC_UCHAR mode, GDC_UCHAR source) 
Parameter mode Chroma-key mode selection 
GDC_ENABLE Chroma-key operation enable 
GDC_DISABLE Chroma-key operation disable 
source Source key color selection 
GDC_CHROMAKEY_C C layer color 
GDC_CHROMAKEY_DISP Display color 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code None 


Description Sets whether Chroma-key is operated. When Chroma-key is operated, select target to 
be compared between C layer color and display color. When Chroma-key is not 
operated, setting of target of key color to be compared has no meaning. 


This command can be used by all “Graphics Controller”. 


6.4.5 GdcColorKey [Sets key color for Chroma-key] 


Format int GdcColorKey (GDC_COL16 color) 
Parameter color Key color for Chroma-key operation 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code None 
Description Sets the key color for Chroma-key operation. In indirect mode, the lower 8bit of this 


key color is applied as the color code of the key color. 


This command can be used by all “Graphics Controller”. 
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6.4.6 GdcColorPaletteOffset [Sets of the color palette offset] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcColorPalette (GDC_UCHAR layer, GDC_UCHAR number, 
GDC_UCHAR size, GDC_LPPCOL 32 IpColor) 


layer Palette selection 


GDC_C_LAYER_PALETTE _ Selects C layer palette 
GDC_MB_LAYER_PALETTE Selects MB layer palette 
GDC_LO LAYER_PALETTE Selects LO layer palette 
(same as C layer palette) 
GDC_L1LAYER_PALETTE Selects L1 layer palette 
(Same as MB layer palette) 
GDC_L2 LAYER_PALETTE Selects L2 layer palette 
GDC_L3 LAYER_PALETTE Selects L3 layer palette 


sub_no Sub palette number (Serial number of 16 divided parts of 256 
palette) 
The range of value is 0-15, and more than 16 are not valid 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_INVALID_LAYER (Invalid layer is specified) 

Sets the sub palette number of the color palette. 

Sub palette number is the serial number of 16 divided parts of 256 palette. 

This command is for MB86293 or later. 
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[Example of usage of the GdcColorPaletteOffset command] 
Example for changing color set number to each sub palette numbers is shown in the figure 6.4.6. 


In this example, 16 sub palettes have been already assigned to LO layer palette. 


GdcColorPaletteOffset(GDC_LO LAYER_PALETTE, “sub palette number”) 


LO layer palette 


sub palette number 0 palette 0 Palette 0 of sub palette number 0 


palette 15 Palette 15 of sub palette number 0 


sub palette number 1 palette 16 Palette 0 of sub palette number 1 


palette 31 Palette 15 of sub palette number 1 


sub palette number 15 palette 240 Palette 0 of sub palette number 15 


palette 255 Palette 15 of sub palette number 15 


Figure 6.4.6 Example of usage of the GdcColorPaletteOffset command 
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6.5 Cursor Control Commands 


6.5.1 GdcCursorAddress [Sets cursor pattern memory address] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcCursorAddress (GDC_UCHAR numCursor, GDC_ULONG ladrs) 


numCursor Cursor number (0 or 1) 
ladrs Cursor pattern address 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_INVALID_CURSOR_NUMBER (Invalid cursor number is specified) 
Sets the start address of the graphics memory where the cursor pattern is stored. 


This command can be used by all “Graphics Controller”. 


6.5.2 GdcCursorPattern [Sets cursor pattern] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcCursorPattern (GDC_UCHAR numCursor, GDC_LPCOL8 IpCursor) 


numCursor Cursor number (0 or 1) 
IpCursor Pointer of cursor pattern 
GDC_TRUE Complete 

GDC_FALSE Incomplete 


GDC_ERR_INVALID_CURSOR_NUMBER (Invalid cursor number is specified) 
Sets a cursor pattern. Transfer a cursor pattern data in main memory pointed via 
IpCursor to the graphics memory that start address is designated by the 
GdcCursorAddress command. 

Size of cursor pattern is fixed to 64*64. 


This command can be used by all “Graphics Controller”. 
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6.5.3. GdcCursorDisplay [Controls cursor display] 


Format int GdcCursorDisplay (GDC_UCHAR numCursor, GDC_UCHAR enable) 
Parameter numCursor Cursor number (0 or 1) 
enable Cursor display ON/OFF 
GDC_ENABLE Cursor display ON 
GDC_DISABLE Cursor display OF F 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_CURSOR_NUMBER (Invalid cursor number is specified) 
Description Controls cursor display ON or OFF. 


This command can be used by all “Graphics Controller”. 


6.5.4 GdcCursorPos [Sets cursor display position] 


Format int GdcCursorPos (GDC_UCHAR numCursor, GDC_USHORT x, GDC_USHORT y) 
Parameter numCursor Cursor number (0 or 1) 

x x coordinates of cursor display position 

y y coordinates of cursor display position 
Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code GDC_ERR_INVALID_CURSOR_NUMBER (Invalid cursor number is specified) 
Description Sets display position of cursor. 


This command can be used by all “Graphics Controller”. 
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6.5.5 GdcCursorPriority [Sets cursor display priority mode] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcCursorPriority (GDC_UCHAR numCursor, GDC_UCHAR mode) 


numcCursor Cursor number (0 or 1) 


mode Cursor display priority mode 


GDC_PRIORITY_C_LAYER  C layer is prioritized 
GDC_PRIORITY_CURSOR Cursor is prioritized 


GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_INVALID_CURSOR_NUMBER (Invalid cursor number is specified) 
Selects which is prioritized in display, C layer or cursor. 


This command can be used by all “Graphics Controller”. 


6.5.6 GdcCursorColorTransparent [Sets cursor transparent color] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcCursorColorTransparent (GDC_COL8 color) 


color Color code to be treat as transparent color 
GDC_TRUE Complete 

GDC_FALSE Incomplete 

None 


Sets a transparent color code for cursor. 


This command can be used by all “Graphics Controller”. 
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6.5.7 GdcCursorColorZeroMode [Sets cursor color code 0 mode] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcCursorColorZeroM ode (GDC_UCHAR mode) 


mode Color code 0 mode 
GDC_COLOR_NOTRANSPARENT _ Not transparent color 
GDC_COLOR_TRANSPARENT Transparent color 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_INVALID_COLOR_MODE (Invalid color mode is specified) 
Selects the color option applied for color code 0 in cursor pattern. Color code 0 is treat 
as either transparent color or ordinary color code. 


This command can be used by all “Graphics Controller”. 


MB 86290 Series 
Graphics Driver Users Manual 


84 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.6 Drawing Frame Control Commands 


6.6.1 GdcDrawDimension [Sets drawing frame] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcDrawDimension (GDC_UCHAR cmode, GDC_ULONG daadrs, 
GDC_USHORT dw, GDC_USHORT dh) 


cmode Color mode 


GDC_24BPP_FORMAT 24 bits color mode 
GDC_16BPP_FORMAT 16 bits color mode (default) 
GDC_8BPP_FORMAT _ 8bits color mode 


dadrs Drawing frame base address 

dw Drawing frame width (pixel unit) 
dh Drawing frame height (pixel unit) 
GDC_TRUE Complete 

GDC_FALSE Incomplete 


GDC_ERR_INVALID_COLOR_MODE (Invalid color mode is specified) 
Sets color mode and size of drawing frame. 


This command can be used by all “Graphics Controller”. 


6.6.2 GdcSetZPrecision [Sets precision of Z value] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcSetZPrecision (GDC_ULONG mode) 


mode Precision of Z value 


GDC_Z 16BIT Precision of Z value is 16 bits (default) 
GDC_Z 8BIT Precision of Z value is 8 bits 


GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Sets precision of Z value. 


This command is for MB86293 or later. 
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6.6.3 GdcBufferCreateZ [Sets Z buffer base address] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcBufferCreateZ (GDC_ULONG zadrs) 


zadrs Z buffer base address 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets the base address of Z buffer. The vertical/horizontal size of Z buffer is assumed to 
be equal to that of drawing frame. 

When precision of Z value is 16 bits, memory size of 16 bits per 1 pixel is needed. 
When precision of Z value is 8 bits, memory size of 8 bits per 1 pixel is needed. 


This command can be used by all “Graphics Controller”. 


6.6.4 GdcBufferCreateC [Sets base address of polygon drawing flag buffer] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcBufferCreateC (GDC_ULONG cadrs) 


cadrs Polygon drawing control buffer base address 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets the base address of polygon drawing control buffer. The vertical/horizontal size of 
this control buffer is assumed to be equal to that of drawing frame. For each pixel, 
1bit of data is required for this buffer. 


This command can be used by all “Graphics Controller”. 


6.6.5 GdcBufferClearZ [Clears Z buffer] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcBufferClearZ (void) 


None 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Clears Z buffer. Prior to hidden surface manipulation, Z buffer should be cleared. 


This command can be used by all “Graphics Controller”. 
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6.6.6 GdcBufferClearC [Clears polygon drawing flag buffer] 


Format int GdcBufferClearC (void) 
Parameter None 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Clears polygon drawing flag buffer. 


This command can be used by all “Graphics Controller”. 


6.6.7 GdcDrawClipFrame [Sets drawing clip border] 


Format int GdcDrawClipFrame (GDC_USHORT x0, GDC_USHORT yo, 
GDC_USHORT x1, GDC_USHORT y1) 


Parameter x0 x coordinates of left top edge of clip border 
yO y coordinates of left top edge of clip border 
xl x coordinates of right bottom edge of clip border 
yl y coordinates of right bottom edge of clip border 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets clip border of drawing. Clip border is set as a BIt located relatively from the base 


point of drawing frame. Drawing to the area outside of this dip border is not 
performed. 


This command can be used by all “Graphics Controller”. 
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6.6.8 GdcSetAlphaMapBase [Sets base address of alpha map area] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcSetAlphaMapBase (GDC_ULONG adrs) 


adrs Alpha map area base address 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets the base address of alpha map area. 

Alpha map area is an alpha coeffident area to be used by the GdcBItCopyAltAlpha 
command. An offset from the graphics memory top must be set to “adrs”. 

For details about alpha map, refer to hardware specification of the “Graphics 
Controller”. 


This command is for MB86293 of later. 
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6.7 Primitive Drawing Commands for Device Coordinates 


6.7.1. GdcPrimType [Starts drawing procedure] 


Format int GdcPrimType (GDC_UCHAR type) 

Parameter type Sets primitive type 
GDC_POINTS Point 
GDC _LINE Line 
GDC_POLYLINE Poly-line 
GDC_LINES_FAST Fast 2D line 
GDC_POLYLINE_FAST Fast 2D poly-line 
GDC_TRIANGLES Triangle 
GDC_TRIANGLE_STRIP Triangle strip 
GDC_TRIANGLE_FAN Triangle fan 
GDC_POLYGON Polygon 
GDC_TRIANGLES FAST Fast 2D triangle 
GDC_TRIANGLE_STRIP_FAST Fast 2D triangle strip 
GDC_TRIANGLE_FAN_FAST Fast 2D triangle fan 

Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code - GDC_ERR_INVALID_PRIMITIVE (Invalid primitive is specified) 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Description Sets the primitive type to be drawn by the GdcDrawVertex2D[i] or the 
GdcDrawVertex3D[f] command. Once either of these commands is executed, same 
type of primitive will keep being drawn till the GdcPrimEnd command will be 
executed. 


This command can be used by all “Graphics Controller”. 


6.7.2 GdcPrimEnd [Completes drawing procedure] 


Format void GdcPrimEnd (void) 


Parameter None 
Return value None 
Description Stops drawing the primitive applied by the GdcPrimT ype command. 


This command can be used by all “Graphics Controller”. 
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6.7.3. GdcTexCoord2D / 2Df / 2DNf [Sets coordinates of 2D texture] 


Format 


Parameter 


Return value 


Description 


void GdcTexCoord2D (GDC_FIXED32 u, GDC_FIXED3z2 v) 
void GdcTexCoord2Df (GDC_SFLOAT u, GDC_SFLOAT v) 
void GdcTexCoord2DNf (GDC_SFLOAT u, GDC_SFLOAT v) 


U u coordinates of texture mapped on the vertex 
V v coordinates of texture mapped on the vertex 
None 


Sets the texture coordinates for the vertex to be drawn by the vertex coordinate 
setting command. Once this command is executed, the same texture coordinates is 
continuously applied till this command will be executed. 

The GdcT exCoord2D command must be used when the type of texture coordinate is 
GDC_FIXED32. 

The GdcT exCoord2Df command must be used when the type of texture coordinate is 
GDC_SFLOAT. 

The GdcT exCoord2DNf command must be used when the type of texture coordinate is 
GDC_SFLOAT and normalized. In this case, the range of texture coordinate must be 
within 0.0 to 1.0. The minimum size of texture coordinate is 0.0 and the maximum 
size is 1.0. 


This command is applicable to the following primitives: 


GDC_TRIANGLES 
GDC_TRIANGLE_STRIP 
GDC_TRIANGLE_FAN 


This command can be used by all “Graphics Controller”. 
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6.7.4 GdcTexCoord3D / 3Df / 3DNf [Sets coordinates of 3D texture] 


Format 


Parameter 


Return value 


Description 


void GdcTexCoord3D (GDC_FIXED32 u, GDC_FIXED32 v, GDC_FIXED32 rw) 
void GdcTexCoord3Df (GDC_SFLOAT u, GDC_SFLOAT v, GDC_SFLOAT rw) 
void GdcTexCoord3DNf (GDC_SFLOAT u, GDC_SFLOAT v, GDC_SFLOAT rw) 


U u coordinates of texture mapped on the vertex 

V v coordinates of texture mapped on the vertex 

rw Reciprocal of w coordinates of texture mapped on the vertex 
None 


Sets the texture coordinates for the vertex to be drawn by the vertex coordinate setting 
command. Once this command is executed, the same texture coordinates is 
continuously applied till this command will be executed. 

The GdcT exCoord3D command must be used when the type of texture coordinate is 
GDC_FIXED3z2. 

The GdcT exCoord3Df command must be used when the type of texture coordinate is 
GDC_SFLOAT. 

The GdcT exCoord3DNf command must be used when the type of texture coordinate is 
GDC_SFLOAT and normalized. In this case, the range of texture coordinate must be 
within 0.0 to 1.0. The minimum size of texture coordinate is 0.0 and the maximum size 
is 1.0. 


This command is applicable to the following primitives: 


GDC_TRIANGLES 
GDC_TRIANGLE_STRIP 
GDC_TRIANGLE_FAN 


This command can be used by all “Graphics Controller”. 
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6.7.5 GdcDrawVertex2D / 2Di [Sets coordinates of 2D vertex] 


Format 


Parameter 


Return value 


Description 


void GdcDrawVertex2D (GDC_FIXED32 x, GDC_FIXED32 y) 
void GdcDrawVertex2Di (GDC_LONG x, GDC_LONG y) 


Xx Xx coordinates of 2D vertex 
y y coordinates of 2D vertex 
None 


Sets 2D vertex coordinates and drawing a designated primitive. 

Current values of color and texture coordinates are used in drawing, which has been 
set by the vertex color setting command and texture coordinates setting command 
respectively. 

The GdcDrawVertex2D command must be used when the type of vertex coordinate is 
GDC_FIXED3z2. 

The GdcDrawVertex2Di command must be used when the type of vertex coordinate is 
GDC_LONG. 


The GdcDrawVertex2Di command is applicable to the following primitives: 


GDC_LINES FAST 
GDC_POLYLINE_FAST 
GDC_POLYGON 
GDC_TRIANGLES FAST 
GDC_TRIANGLE_STRIP_FAST 
GDC_TRIANGLE_FAN_FAST 


This command can be used by all “Graphics Controller”. 
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6.7.6 GdcDrawVertex3D / 3Df [Sets coordinates of 3D vertex] 


Format 


Parameter 


Return value 


Description 


void GdcDrawVertex3D (GDC_FIXED32 x, GDC_FIXED32 y, GDC_USHORT z) 
void GdcDrawVertex3Df (GDC_SFLOAT x, GDC_SFLOAT y, GDC_SFLOAT z) 


x x coordinates of 3D vertex 
y y coordinates of 3D vertex 
Z z coordinates of 3D vertex 
None 


Sets 3D vertex coordinates and drawing a designated primitive. 

Current values of color and texture coordinates are used in drawing, which has been 
set by the vertex color setting command and texture coordinates setting command 
respectively. 

The GdcDrawVertex3D command must be used when the type of vertex coordinate is 
GDC_FIXED3z2. 

The GdcDrawVertex3Df command must be used when the type of vertex coordinate is 
GDC_SFLOAT. 


The GdcDrawVertex3Df command is applicable to the following primitives: 


GDC_TRIANGLES 
GDC_TRIANGLE_STRIP 
GDC_TRIANGLE_FAN 


When drawing a polygon primitive (GDC_POLY GON), z coordinates of a parameter is 
disregarded. 


This command can be used by all “Graphics Controller”. 
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6.7.7 GdcDrawPrimitive [Draws multiple 3D triangles] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcDrawPrimitive (GDC_ULONG type, GDC_VERTEX IpVertices, int count) 


type Sets primitive type 
GDC_TRIANGLES Triangle 
GDC_TRIANGLE_STRIP Triangle strip 
GDC_TRIANGLE_FAN Triangle fan 

IpVertices Pointer of vertex parameter list (coordinates, color texture 

coordinates) 

count Number of vertices 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

None 


Draws a primitive specified in the type formed with multiple vertices designated by 
IpVertices. 


This command can be used by all “Graphics Controller”. 
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6.8 Primitive Drawing Control Commands for Object 


Coordinates 


6.8.1 GdcGeoPrimType [Starts drawing procedure] 


Format int GdcGeoPrimT ype (GDC_UCHAR type) 

Parameter Type Sets primitive type 
GDC_POINTS Point 
GDC_LINES Line 
GDC_POLYLINE Poly-line 
GDC_TRIANGLES Triangle 
GDC_TRIANGLE_STRIP Triangle strip 
GDC_TRIANGLE_FAN Triangle fan 
GDC_POLYGON Polygon 

Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code - GDC_ERR_INVALID_PRIMITIVE (Invalid primitive is specified) 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Description Sets primitive drawn with GdcGeoDrawVertex2D[f/i] or GdcGeoDrawVertex3D[f/i]. 
Once this command is executed, the same primitive is drawn until the 
GdcGeoPrimEnd command is executed. 


This command is for MB86291 or later. 


6.8.2 GdcGeoPrimEnd [Completes drawing procedure] 


Format void GdcGeoPrimEnd (void) 

Parameter None 

Return value None 

Description Terminates a series of processes to draw primitives fallowing the GdcGeoPrimT ype 
command. 


This command is for MB86291 or later. 
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6.8.3 GdcGeoDrawVertex2D / 2Df / 2Di [Sets XY coordinates of vertex ] 


Format 


Parameter 


Return value 


Description 


void GdcGeoDrawVertex2D (GDC_FIXED32 x, GDC_FIXED3z2 y) 
void GdcGeoDrawVertex2Df (GDC_SFLOAT x, GDC_SFLOAT y) 
void GdcGeoDrawVertex2Di (GDC_LONG x, GDC_LONG y) 


Xx x coordinates of the vertex 
y y coordinates of the vertex 
None 


Specifies a vertex coordinates in object coordinates and drawing a primitive currently 
set. In this case, z is treated as zero. 

Current values of color and texture coordinates are used in drawing, which has been 
set by the vertex color setting command and texture coordinates setting command 
respectively. 

The GdcGeoDrawVertex2D command must be used when the type of vertex coordinate 
is GDC_FIXED32. 

The GdcGeoDrawVertex2Df command must be used when the type of vertex 
coordinate is GDC_SFLOAT. 

The GdcGeoDrawVertex2Di command must be used when the type of vertex coordinate 
is GDC_LONG. 

This command is for MB86291 or later. 
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6.8.4 GdcGeoDrawVertex3D / 3Df / 3Di [Sets XYZ coordinates of vertex] 


Format 


Parameter 


Return value 


Description 


void GdcGeoDrawVertex3D (GDC_FIXED32 x,GDC_FIXED32 y, GDC_FIXED3z2 z) 
void GdcGeoDrawVertex3Df (GDC_SFLOAT x, GDC_SFLOAT y, GDC_SFLOAT z) 
void GdcGeoDrawVertex3Di (GDC_LONG x, GDC_LONG y, GDC_F1IXED32 z) 


x x coordinates of the vertex 
y y coordinates of the vertex 
Z z coordinates of the vertex 
None Complete 


Sets vertex coordinates in object coordinates and drawing a primitive currently set. In 
this case, z is treated as zero. 

Current values of color and texture coordinates are used in drawing, which has been 
set by the vertex color setting command and texture coordinates setting command 
respectively. 

The GdcGeoDrawVertex3D command must be used when the type of vertex coordinate 
is GDC_FIXED32. 

The GdcGeoDrawVertex3Df command must be used when the type of vertex 
coordinate is GDC_SFLOAT. 

The GdcGeoDrawVertex3Di command must be used when the type of vertex coordinate 
is GDC_LONG. 

However, when drawing a polygon primitive (GDC_POLYGON) by MB86291/86292, z 
coordinates of a parameter is disregarded. 


This command is for MB86291 or later. 
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6.8.5 GdcGeoTexCoord2DN / 2DNf [Sets texture coordinates] 


Format 


Parameter 


Return value 


Description 


void GdcGeoTexCoord2DN (GDC_FIXED32 u, GDC_FIXED32 v) 
void GdcGeoT exCoord2DNf (GDC_SFLOAT u, GDC_SFLOAT v) 


u Texture u coordinates of the vertex 
Vv Texture v coordinates of the vertex 
None 


Sets a texture coordinates (2 dimensions) of vertex in drawing with the vertex 
coordinates setting command. Once this command is executed, the same texture 
coordinates is used in drawing unless texture coordinates is changed by this command. 
This command treat texture coordinates as normalized (1.0 is maximum size of current 
texture). 

The GdcGeoT exCoord2DN command must be used when the type of texture coordinate 
is GDC_FIXED32. 

The GdcGeoT exCoord2DNf command must be used when the type of texture 
coordinate is GDC_SFLOAT. 


This command is applicable to the following primitives: 


GDC_TRIANGLES 
GDC_TRIANGLE_STRIP 
GDC_TRIANGLE_FAN 


However, MB86293 or later can also be used the following primitives: 


GDC_POLYGON 
This command is for MB86291 or later. 
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6.8.6 GdcVertexColor3f / 32 [Sets color of vertex] 


Format 


Parameter 


Return value 


Description 


void GdcVertexColor32 (GDC_COLOR3z2 color) 
void GdcVertexColor3f (GDC_SFLOAT r, GDC_SFLOAT g, GDC_SFLOAT b) 


color Packed format in which each color elements (r,g,b) is normalized to 
[0,255]. In this case, r,g,b are 8 bits respectively. 

r,g,b Normalized values in which each color elements (r,g,b) are 
normalized to [0,1]. 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

Sets a color of vertex. Once this command is executed, the same color is used in 

drawing for object coordinates unless the color is changed by this command. 

This command is used when shading mode is smooth shading. If the shading mode is 

flat shading, use GdcColor. 

The GdcVertexColor32 command must be used when the type of vertex color is 

GDC_COLOR32. 

The GdcVertexColor3f command must be used when the type of vertex color is 

GDC_SFLOAT. 

When drawing a polygon (GDC_POLYGON), setup of this command is disregarded. 

This command is for MB86291 or later. 
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6.9 Drawing Attribute Control Commands 


6.9.1 GdcColor [Sets vertex color/foreground color] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcColor (GDC_COLOR3z2 color) 


color Vertex and foreground color 
GDC_TRUE Complete 

GDC_FALSE Incomplete 

None 


Sets vertex color and foreground color applied for bitmap drawing and broken line 
drawing to be executed by set coordinates of vertex command. Once this command is 
executed, the same color is continuously applied till this command will be executed. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command can be used by all “Graphics Controller”. 
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6.9.2 GdcBackColor [Sets background color] 


Format int GdcBackColor (GDC_COLOR3z2 color) 
Parameter color Background color 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code None 
Description Sets background color applied for binary pattern drawing and broken line drawing. 


Once this command is executed, the same color is continuously applied till this 
command will be executed. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


In order to make background color transparent, sets the following bit as 1 by color 


mode. 
- 8 bits color mode : bit 15 of “color” 
- 16 bits color mode : bit 15 of “color” 
- 24 bits color mode : bit 31 of “color” 


This command can be used by all “Graphics Controller”. 


6.9.3. GdcClipMode [Sets clipping mode] 


Format int GdcClipMode (GDC_ULONG mode) 

Parameter mode Clipping mode 
GDC_CLIP_X_ON Validates clipping toward x axis 
GDC_CLIP_Y_ON Validates clipping toward y axis 


GDC_CLIP_DISABLE __ Invalidates dipping 


Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


Description Sets clipping mode. 
GDC_CLIP_X_ON and GDC_CLIP_Y_ON can beset at the same time with OR 
operator. 


This command can be used by all “Graphics Controller”. 
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6.9.4 GdcSetAttrLine [Sets line drawing attribute] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcSetAttrLine (GDC_ULONG target, GDC_ULONG param) 


target 


param 
GDC_TRUE 
GDC_FALSE 


Line drawing attribute 


GDC_DEPTH_TEST Z value compare mode 
GDC_DEPTH_FUNC Z value compare type 
GDC_DEPTH_WRITE_MASK Z value write permission mask 
GDC_BLEND_MODE Blending mode 
GDC_BROKEN LINE Broken line mode 
GDC_LINE_WIDTH Line width 
GDC_ANTI_ALIAS Antialias option 
GDC_LINE_ENDPOINT End of the line control 


[When the “Graphics Controller” is MB86291 or later, following 
functions are available] 
GDC_BROKEN_LINE_OFFSET Offset control of broken line 
pattern 
GDC_BROKEN_LINE_ PERIOD Period set of broken line pattern 


[When the “Graphics Controller” is MB86293 or later, following 
functions are available] 
GDC_SHADOW_DEPTH_TEST Z value compare mode of shadow 
GDC_SHADOW_DEPTH_FUNC  Z value compare type of shadow 
GDC_SHADOW_DEPTH_WRITE_MASK 
Z value write permission mask 
of shadow 
GDC_SHADOW_BLEND MODE _ Blending mode of shadow 
GDC_SHADOW_BROKEN_LINE Broken line mode of shadow 
GDC_SHADOW_LINE_WIDTH Line width of shadow 
GDC_SHADOW_BROKEN_LINE_PERIOD 
Period set of broken line pattern of 
shadow 
GDC_BORDER_DEPTH_TEST Z value compare mode of border 
GDC_BORDER_DEPTH_FUNC ~~ Z valuecompare type of border 
GDC_BORDER_DEPTH_WRITE_MASK 
Z value write permission mask 
of border 
GDC_BORDER_BLEND_MODE _ Blending mode of border 
GDC_BORDER_BROKEN_LINE _ Broken line mode of border 
GDC_BORDER_LINE_WIDTH Line width of border 
GDC_BORDER_BROKEN LINE PERIOD 
Period set of broken line pattern of 
border 


Parameter corresponding to target (*1) 


Complete 


Incomplete 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
- GDC_ERR_ILLEGAL_LINE_WIDTH (Illegal width of line) 
- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 


Sets attribute for line drawing. 


This command can be used by all “Graphics Controller”. 
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(*1) Line drawing attribute (target) and parameter (param) corresponding to each line drawing attribute 


is shown below. 


[Explanatory notes] 
Line drawing attribute 
Parameter 1 that can set 
Parameter 2 that can set 


GDC_DEPTH_TEST 
GDC_ENABLE 
GDC_DISABLE 


GDC_DEPTH_FUNC 
GDC_DEPTH_NEVER 
GDC_DEPTH ALWAYS 
GDC_DEPTH_LESS 
GDC_DEPTH_LEQUAL 


GDC_DEPTH_EQUAL 
GDC_DEPTH_GEQUAL 


GDC_DEPTH_GREATER 
GDC_DEPTH_NOTEQUAL 


GDC_DEPTH_WRITE_MASK 
GDC_ENABLE 
GDC_DISABLE 


GDC_BLEND_MODE 
GDC_BLEND_COPY 


GDC_BLEND_ALPHA 
GDC_BLEND_ROP 


GDC_BROKEN _LINE 
GDC_ENABLE 
GDC_DISABLE 


GDC_LINE_WIDTH 
GDC_LINE_WIDTH_1 
GDC_LINE_WIDTH_2 
GDC_LINE_WIDTH_32 

GDC_ANTI_ALIAS 
GDC_ENABLE 
GDC_DISABLE 


GDC_LINE_ENDPOINT 


GDC_ENABLE 
GDC_DISABLE 


Description of line drawing attribute 
Description of parameter 1 
Description of parameter 2 


Sets Z value compare mode. 
Validates Z value comparison. 
Invalidates Z value comparison. 


Selects Z value comparison type. 

Always NOT drawn. 

Always drawn. 

Drawn if current Z value is less than Z buffer value. 
Drawn if current Z value equal to or less than Z buffer 
value. 

Drawn if current Z value equal to Z buffer value. 
Drawn if current Z value equal to or more than Z buffer 
value. 

Drawn if current Z value more than Z buffer value. 
Drawn if current Z value is not equal to Z buffer value. 


Enables write access to Z buffer. 

If GDC_ENABLE, according to the result of Z value 
comparison, Z value is written to Z buffer. 

Disable Z buffer write. 

Enable Z buffer write. 


Sets blending mode of pixel write. 

Regular drawing operation (writes pixel 
drawing frame). 

Enables alpha blending. 

Draws with logical arithmetic. 


color to 


Selects broken line mode. 
Draws a broken line utilizing applied line pattern. 
Draws a solid line 


Sets line width. 
Draws a line of 1 pixel width. 
Draws a line of 2 pixel width. 


Draws a line of 32 pixel width. 


Sets antialias mode. 
Enables antialias operation. 
Disables antialias operation. 


Controls the end point of line in GDC_LINES and 
GDC_LINES_FAST commands. 

End point is not drawn in GDC _POLYLINE and 
GDC_POLYLINE_FAST commands regardless this 
setting. 

Draws the end point. 

NOT draws the end point. 
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GDC_BROKEN_LINE_OFFSET 


GDC_ENABLE 
GDC_DISABLE 


GDC_BROKEN_LINE_PERIOD 


GDC_BROKEN _LINE_32 
GDC_BROKEN_LINE_24 


GDC_SHADOW_DEPTH_TEST 


GDC_ENABLE 
GDC_DISABLE 


GDC_SHADOW_DEPTH_FUNC 
GDC_DEPTH NEVER 
GDC_DEPTH ALWAYS 
GDC_DEPTH_LESS 
GDC_DEPTH_LEQUAL 


GDC_DEPTH_EQUAL 
GDC_DEPTH_GEQUAL 


GDC_DEPTH_GREATER 
GDC_DEPTH_NOTEQUAL 


GDC_SHADOW_DEPTH_WRITE_MASK 


GDC_ENABLE 
GDC_DISABLE 


GDC_SHADOW_BLEND_MODE 
GDC_BLEND_COPY 


GDC_BLEND ALPHA 
GDC_BLEND_ROP 


GDC_SHADOW_BROKEN_LINE 


GDC_ENABLE 
GDC_DISABLE 


GDC_SHADOW_LINE_WIDTH 
GDC_LINE_WIDTH_1 
GDC_LINE_WIDTH_2 
GDC_LINE_WIDTH_32 

GDC_SHADOW_BROKEN_LINE_PERIOD 


GDC_BROKEN_LINE_32 
GDC_BROKEN_LINE_24 


Specifies the way of drawing broken line 

(only for MB86291 or later). 

Starts new drawing broken line pattern. 

Continues from the last drawing broken line pattern. 


Sets broken line pattern period (only for MB86291 or 
later). 

32 bits period. 

24 bits period. 


Sets Z value compare mode of shadow (only for 
MB86293 or later). 

Validates Z value comparison. 

Invalidates Z value comparison. 


Selects Z value comparison type of shadow (only for 
MB86293 or later). 

Always NOT drawn. 

Always drawn. 

Drawn if current Z value is less than Z buffer value. 
Drawn if current Z value equal to or less than Z buffer 
value. 

Drawn if current Z value equal to Z buffer value. 
Drawn if current Z value equal to or more than Z buffer 
value. 

Drawn if current Z value more than Z buffer value. 
Drawn if current Z value is not equal to Z buffer value. 


Enables write access to Z buffer of shadow (only for 
MB86293 or later). 

Disable Z buffer write. 

Enable Z buffer write. 


Sets blending mode of pixel write of shadow (only for 
MB86293 or later). 

Regular drawing operation 
drawing frame). 

Enables alpha blending. 
Draws with logical arithmetic. 


(writes pixel color to 


Selects broken line mode of shadow (only for MB86293 
or later). 

Draws a broken line utilizing applied line pattern. 
Draws a solid line 


Sets line width of shadow (only for MB86293 or later). 
Draws a line of 1 pixel width. 
Draws a line of 2 pixel width. 


Draws a line of 32 pixel width. 


Sets broken line pattern period of shadow (only for 
MB86293 or later). 

32 bits period. 

24 bits period. 
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GDC_BORDER_DEPTH_TEST 


GDC_ENABLE 
GDC_DISABLE 


GDC_BORDER_DEPTH_FUNC 
GDC_DEPTH NEVER 
GDC_DEPTH ALWAYS 
GDC_DEPTH_LESS 
GDC_DEPTH_LEQUAL 


GDC_DEPTH_EQUAL 
GDC_DEPTH_GEQUAL 


GDC_DEPTH_GREATER 
GDC_DEPTH_NOTEQUAL 


GDC_BORDER_DEPTH_WRITE_MASK 


GDC_ENABLE 
GDC_DISABLE 


GDC_BORDER_BLEND MODE 
GDC_BLEND_COPY 


GDC_BLEND_ALPHA 
GDC_BLEND_ROP 


GDC_BORDER_BROKEN_LINE 


GDC_ENABLE 
GDC_DISABLE 


GDC_BORDER_LINE_WIDTH 
GDC_LINE_WIDTH_1 
GDC_LINE_WIDTH_2 
GDC_LINE_WIDTH_32 

GDC_BORDER_BROKEN_LINE_PERIOD 


GDC_BROKEN_LINE_32 
GDC_BROKEN_LINE_24 


Sets Z value compare mode of border (only for MB86293 
or later). 

Validates Z value comparison. 

Invalidates Z value comparison. 


Selects Z value comparison type of border (only for 
MB86293 or later). 

Always NOT drawn. 

Always drawn. 

Drawn if current Z value is less than Z buffer value. 
Drawn if current Z value equal to or less than Z buffer 
value. 

Drawn if current Z value equal to Z buffer value. 
Drawn if current Z value equal to or more than Z buffer 
value. 

Drawn if current Z value more than Z buffer value. 
Drawn if current Z value is not equal to Z buffer value. 


Enables write access to Z buffer of border (only for 
MB86293 or later). 

Disable Z buffer write. 

Enable Z buffer write. 


Sets blending mode of pixel write of border (only for 
MB86293 or later). 

Regular drawing operation 
drawing frame). 

Enables alpha blending. 
Draws with logical arithmetic. 


(writes pixel color to 


Selects broken line mode of border (only for MB86293 
or later). 

Draws a broken line utilizing applied line pattern. 
Draws a solid line 


Sets line width of border (only for MB86293 or later). 
Draws a line of 1 pixel width. 
Draws a line of 2 pixel width. 


Draws a line of 32 pixel width. 


Sets broken line pattern period of border (only for 
MB86293 or later). 
32 bits period. 
24 bits period. 
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6.9.5 GdcSetAttrSurf [Sets surface drawing attribute] 


Format int GdcSetAttrSurf (GDC_ULONG target, GDC_ULONG param) 

Parameter target Surface drawing attribute 
GDC_SHADE_MODE Shading mode 
GDC_DEPTH_TEST Z value compare mode 
GDC_DEPTH_FUNC Z value compare type 
GDC_DEPTH_WRITE_MASK Z value write mask 
GDC_BLEND_MODE Blending mode 
GDC_TEXTURE_SELECT Texture mode 


[When the “Graphics Controller” is MB86293 or later, following 
functions are available] 

GDC_ALPHA_SHADE_MODE Alpha shading mode 
GDC_SHADOW_DEPTH_TEST Z value compare mode of 

shadow 
GDC_SHADOW_DEPTH_FUNC Z value compare type of 

shadow 
GDC_SHADOW_DEPTH_WRITE_MASK 

Z value write mask of shadow 
GDC_SHADOW_BLEND MODE _ Blending mode of shadow 
GDC_NON_TOPLEFT_SHADE_MODE 

Shading mode of non top-left 

primitive 
GDC_NON_TOPLEFT_DEPTH_TEST 

Z value compare mode of non 

top-left primitive 
GDC_NON_TOPLEFT_DEPTH_FUNC 

Z value compare type of non 

top-left primitive 
GDC_NON_TOPLEFT_DEPTH_WRITE_MASK 

Z value write mask of non 

top-left primitive 
GDC_NON_TOPLEFT BLEND MODE 

Blending mode of non 

top-left primitive 
GDC_NON_TOPLEFT_TEXTURE_SELECT 

Texture mode of non 

top-left primitive 
GDC_NON_TOPLEFT_ALPHA_SHADE_MODE 

Alpha shading mode of non 

top-left primitive 


param Parameter corresponding to target (*1) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 
Description Sets attribute for surface drawing (not induding texture mapping attribute). 


This command can be used by all “Graphics Controller”. 
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(*1) Surface drawing attribute (target) and parameter (param) corresponding to each surface drawing 


attribute is shown below. 


[Explanatory notes] 
Surface drawing attribute 
Parameter 1 that can set 
Parameter 2 that can set 


GDC_SHADE_MODE 


GDC_SHADE_FLAT 
GDC_SHADE_SMOOTH 


GDC_DEPTH_TEST 


GDC_ENABLE 
GDC_DISABLE 


GDC_DEPTH_FUNC 


GDC_DEPTH NEVER 
GDC_DEPTH ALWAYS 
GDC_DEPTH_LESS 
GDC_DEPTH_LEQUAL 


GDC_DEPTH_EQUAL 
GDC_DEPTH_GEQUAL 


GDC_DEPTH_GREATER 


GDC_DEPTH_NOTEQUAL 


GDC_DEPTH_WRITE_MASK 


GDC_ENABLE 
GDC_DISABLE 


GDC_BLEND_MODE 
GDC_BLEND_COPY 


GDC_BLEND_ALPHA 
GDC_BLEND_ROP 


GDC_TEXTURE_SELECT 
GDC_SELECT_TEXTURE 


GDC_SELECT_TILE 
GDC_SELECT_PLAIN 


GDC_ALPHA_SHADE_MODE 


GDC_SHADE_FLAT 
GDC_SHADE_SMOOTH 


Description of surface drawing attribute 
Description of parameter 1 
Description of parameter 2 


Sets shading mode. 


Flat shading. 
Gouraud shading. 


Sets Z value compare mode. 


Validate Z value comparison. 
Invalidate Z value comparison. 


Selects Z value comparison type. 


Always NOT drawn. 

Always drawn. 

Drawn if current Z value is less than Z buffer value. 
Drawn if current Z value is equal to or less than Z buffer 
value. 

Drawn if current Z value is equal to Z buffer value. 
Drawn if current Z value is equal to or more than Z buffer 
value. 

Drawn if current Z value is more than Z buffer value. 
Drawn if current Z value is not equal to Z buffer value. 


Enables write access to Z buffer. 


If GDC_ENABLE, according to the result of Z value 
comparison, Z value is written to Z buffer. 


Disables Z buffer write. 
Enables Z buffer write. 


Sets blending mode of pixel write. 


Regular drawing operation (writes pixel color to drawing 
frame). 

Enables alpha blending. 

Draws with logical arithmetic. 


Sets texture mapping mode. 
Draws with texture mapping. 


Draws with tiling. 
Invalidates texture mapping. 


Sets alpha shading mode (only for MB86293 or later). 


Flat shading. 
Gouraud shading. 


MB 86290 Series 
Graphics Driver Users Manual 


107 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


GDC_SHADOW_DEPTH_TEST 


GDC_ENABLE 
GDC_DISABLE 


GDC_SHADOW_DEPTH_FUNC 


GDC_DEPTH NEVER 
GDC_DEPTH ALWAYS 
GDC_DEPTH_LESS 
GDC_DEPTH_LEQUAL 


GDC_DEPTH_EQUAL 
GDC_DEPTH_GEQUAL 


GDC_DEPTH_GREATER 
GDC_DEPTH_NOTEQUAL 


GDC_SHADOW_DEPTH_WRITE_MASK 


GDC_ENABLE 
GDC_DISABLE 


GDC_SHADOW_BLEND_MODE 


GDC_BLEND_COPY 


GDC_BLEND ALPHA 
GDC_BLEND_ROP 


Sets Z value compare mode of shadow (only for MB86293 
or later). 


Validate Z value comparison. 
Invalidate Z value comparison. 


Selects Z value comparison type of shadow (only for 
MB86293 or later). 


Always NOT drawn. 

Always drawn. 

Drawn if current Z value is less than Z buffer value. 
Drawn if current Z value is equal to or less than Z buffer 
value. 

Drawn if current Z value is equal to Z buffer value. 
Drawn if current Z value is equal to or more than Z buffer 
value. 

Drawn if current Z value is more than Z buffer value. 
Drawn if current Z value is not equal to Z buffer value. 


Enables write access to Z buffer of shadow (only for 
MB86293 or later). 


If GDC_ENABLE, according to the result of Z value 
comparison, Z value is written to Z buffer. 


Disables Z buffer write. 
Enables Z buffer write. 


Sets blending mode of pixel write of shadow (only for 
MB86293 or later). 


Regular drawing operation (writes pixel color to drawing 
frame). 

Enables alpha blending. 

Draws with logical arithmetic. 
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GDC_NON_TOPLEFT_SHADE_MODE 


GDC_SHADE_FLAT 
GDC_SHADE_SMOOTH 


GDC_NON_TOPLEFT_DEPTH_TEST 


GDC_ENABLE 
GDC_DISABLE 


GDC_NON_TOPLEFT_DEPTH_FUNC 


GDC_DEPTH NEVER 
GDC_DEPTH ALWAYS 
GDC_DEPTH_LESS 
GDC_DEPTH_LEQUAL 


GDC_DEPTH_EQUAL 
GDC_DEPTH_GEQUAL 


GDC_DEPTH_ GREATER 
GDC_DEPTH_NOTEQUAL 


GDC_NON_TOPLEFT_DEPTH_WRITE_ 


MASK 


GDC_ENABLE 
GDC_DISABLE 


GDC_NON_TOPLEFT_BLEND MODE 


GDC_BLEND_COPY 


GDC_BLEND_ALPHA 
GDC_BLEND_ROP 


GDC_NON_TOPLEFT_TEXTURE_SELE 
CT 


GDC_SELECT_TEXTURE 
GDC_SELECT_TILE 
GDC_SELECT_PLAIN 


GDC_NON_TOPLEFT_ALPHA_SHADE_ 


MODE 


GDC_SHADE_FLAT 
GDC_SHADE_SMOOTH 


Sets shading mode of non top-left primitive (only for 
MB86293 or later). 


Flat shading. 
Gouraud shading. 


Sets Z value compare mode of non top-left primitive (only 
for MB86293 or later). 


Validate Z value comparison. 
Invalidate Z value comparison. 


Selects Z value comparison type of non top-left primitive 
(only for MB86293 or later). 


Always NOT drawn. 

Always drawn. 

Drawn if current Z value is less than Z buffer value. 
Drawn if current Z value is equal to or less than Z buffer 
value. 

Drawn if current Z value is equal to Z buffer value. 
Drawn if current Z value is equal to or more than Z buffer 
value. 

Drawn if current Z value is more than Z buffer value. 
Drawn if current Z value is not equal to Z buffer value. 


Enables write access to Z buffer of non top-left primitive 
(only for MB86293 or later). 


If GDC_ENABLE, according to the result of Z value 
comparison, Z value is written to Z buffer. 


Disables Z buffer write. 
Enables Z buffer write. 


Sets blending mode of pixel write of non top-left primitive 
(only for MB86293 or later). 


Regular drawing operation (writes pixel color to drawing 
frame). 

Enables alpha blending. 

Draws with logical arithmetic. 


Sets texture mapping mode of non top-left primitive (only 
for MB86293 or later). 


Draws with texture mapping. 
Draws with tiling. 
Invalidates texture mapping. 


Sets alpha shading mode of non top-left primitive (only 
for MB86293 or later). 


Flat shading. 
Gouraud shading. 
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6.9.6 GdcSetAttrTexture [Sets texture mapping attribute] 


Format int GdcSetAttrT exture (GDC_ULONG target, GDC_ULONG param) 


Parameter target Texture mapping attribute 


GDC_TEXTURE_PERSPECTIVE Perspective correction 


GDC_TEXTURE_FILTER Texture filter 
GDC_TEXTURE_WRAP_S S coordinates wrap 
GDC_TEXTURE_WRAP_T T coordinates wrap 
GDC_TEXTURE_BLEND Texture blend mode 
GDC_TEXTURE_ALPHA Texture alpha mode 


[When the “Graphics Controller” is MB86293 or later, following 


function is available] 


GDC_TEXTURE_FAST_ MODE 


param Parameter corresponding to target (*1) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 


Description Sets attribute for texture mapping. 


This command can be used by all “Graphics Controller”. 


(*1) Texture mapping attribute (target) and parameter (param) corresponding to each texture mapping 


attribute is shown below. 


[Explanatory notes] 
Texture mapping attribute 
Parameter 1 that can set 
Parameter 2 that can set 


GDC_TEXTURE_PERSPECTIVE 


GDC_ENABLE 
GDC_DISABLE 


GDC_TEXTURE_FILTER 


GDC_TEXTURE_POINT 
GDC_TEXTURE_BILINEAR 


GDC_TEXTURE_WRAP_S 


GDC_TEXTURE_REPEAT 
GDC_TEXTURE_CLAMP 
GDC_TEXTURE_BORDER 


Description of texture mapping attribute 
Description of parameter 1 
Description of parameter 2 


Selects perspective correction mode. 


Validates perspective correction. 
Invalidates perspective correction (default). 


Selects texture filter mode. 


Point sampling mode (default). 
Bi-linear filtering mode. 


Defines S coordinates wrapping option when S 
coordinates value exceed the texture size. 


Repeats the texture pattern. 
Sets out-most texture color (default). 
Sets defined border color. 
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GDC_TEXTURE_WRAP_T 


GDC_TEXTURE_REPEAT 
GDC_TEXTURE_CLAMP 
GDC_TEXTURE_BORDER 


GDC_TEXTURE_BLEND 


GDC_TEXTURE_DECAL 
GDC_TEXTURE_MODULATE 
GDC_TEXTURE_STENCIL 


GDC_TEXTURE_ALPHA 


GDC_TEXTURE_ALPHA ALL 
GDC_TEXTURE_ALPHA 
STENCIL 


GDC_TEXALPHA ALPHA 
_STENCILALPHA 


GDC_TEXTURE_FAST_MODE 
GDC_ENABLE 


GDC_DISABLE 


Sets T coordinates wrapping option when T coordinates 
value exceed the texture size. 


Repeats the texture pattern. 
Sets out-most texture color (default). 
Sets defined border color. 


Sets blending mode of texture color and polygon color. 


This is applicable only when texture mapping mode is 
selected. 


Texture color is drawn (default). 

Blended color is drawn. 

If MSB of texture color is 1, texture color is drawn, 
otherwise polygon color is drawn. 


Sets alpha blending mode between drawn color and 
current pixel color of the drawing frame. 


This is applicable only when texture mapping and alpha 
blending are selected. 


Alpha blend between post texture mapping color and 
current pixel color of the drawing frame (default). 

If MSB of texture color is 1, texture color is drawn, 
otherwise not drawn. 

If MSB of texture color is 1, alpha blend between texture 
color and current pixel color in the drawing frame is 
performed, otherwise not drawn. 


Sets bi-linear fast mode (only for MB86293 or later). 


Texture mapping is executed at fast speed using a default 
* 4 as texture area. 
A default texture area is used (default). 
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6.9.7 GdcSetAttrBit [Sets BitBIt attribute] 


int GdcSetAttrBIt (GDC_ULONG target, GDC_ULONG param) 


Bitmap drawing attribute 


GDC_BLEND_MODE Blend mode 


[When the “Graphics Controller” is MB86291 or later, 


following function is available] 


GDC_TRANSPARENT_MODE Transparent mode 


Parameter corresponding to target (*1) 
Complete 


Incomplete 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 


Format 

Parameter target 
param 

Return value GDC_TRUE 
GDC_FALSE 

Error code 

Description 


Sets attribute when copying and drawing BitBIt. 


This blend mode setting function can be used by all “Graphics Controller”. 


The transparent mode setting function is only for MB86291 or later. 


Sets the transparent color for the transparent mode with the GdcBItColorTransparent 


command. 


(*1) Bitmap drawing attribute (target) and parameter (param) corresponding to each bitmap drawing 


attributes are shown below. 


[Explanatory notes] 
Bitmap drawing attribute 
Parameter 1 that can set 
Parameter 2 that can set 


GDC_BLEND_MODE 
GDC_BLEND_COPY 


GDC_BLEND_ROP 
GDC_TRANSPARENT_MODE 
GDC_ENABLE 


GDC_DISABLE 


Description of bitmap drawing attributes 
Description of parameter 1 
Description of parameter 2 


Sets blend mode. 


Regular drawing operation (writes pixel color to drawing 


frame). 
Draws with logical arithmetic. 


Sets transparent mode (only for MB86291 or later). 


The color 
command regards as transparent color. 
The color 
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6.9.8 GdcSetAlpha [Sets alpha blend ratio] 


Format int GdcSetAlpha (GDC_UCHAR alpha) 
Parameter alpha Alpha blending ratio (0 - 255) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets the ratio of alpha blending. 


This command can be used by all “Graphics Controller”. 


6.9.9 GdcSetLinePattern [Sets broken line pattern] 


Format int GdcSetLinePattern (GDC_ULONG pattern) 
Parameter pattern Broken line pattern 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets broken line pattern with 32 bits pattern when drawing broken line. 


Upper 24 bits pattern values are set as a broken line pattern, when the period of 
broken line pattern is 24 bits. 

Broken line is drawn with foreground color when the bit of pattern is 1, and drawn 
with background color when the bit is 0. 

Example of broken line with broken line pattern “Oxaaaaaaaa” is shown in the figure 


6.9.9. 


FBFBFBFBFBFBFBFBFBFBFBFBFBFBFBFB 


[meaning of symbol ] 


F: Foreground color 


B: Background color 


Figure 6.9.9 Example of broken line 


This command can be used by all “Graphics Controller”. 
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6.9.10 GdcSetTextureBorder [Sets texture border color] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcSetTextureBorder (GDC_COLOR32 color) 


color Texture border color 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Sets the border color of the texture applied in border mode of texture wrap. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command can be used by all “Graphics Controller”. 
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6.9.11 GdcSetRop [Sets logical calculation mode] 


Format int GdcSetRop (GDC_UCHAR mode) 

Parameter mode Logical arithmetic mode 
[For body] 
GDC_ROP_CLEAR All bits are set to 0 
GDC_ROP_AND s&d 
GDC_ROP_AND_REVERSE s& Id 
GDC_ROP_COPY s 
GDC_ROP_AND_INVERTED is&d 
GDC_ROP_NOP d 
GDC_ROP_XOR s“d 
GDC_ROP_OR s| d 
GDC_ROP_NOR \(s | d) 
GDC_ROP_EQUIV \(s *d) 
GDC_ROP_INVERT Id 
GDC_ROP_OR_REVERSE s| !d 
GDC_ROP_COPY_INVERTED Is 
GDC_ROP_OR_INVERTED Is| d 
GDC_ROP_NAND \(s & d) 
GDC_ROP_SET All bits are set to 1 


[When the “Graphics Controller” is MB86293 or later, following 
functions are available] 
[For shadow] 


GDC_SHADOW_ROP_CLEAR All bits are set to 0 


GDC_SHADOW_ROP_AND s&d 
GDC_SHADOW_ROP_AND REVERSE s&'d 
GDC_SHADOW_ROP_COPY s 
GDC_SHADOW_ROP_AND_INVERTED !s&d 
GDC_SHADOW_ROP_NOP d 
GDC_SHADOW_ROP_XOR s“~d 
GDC_SHADOW_ROP_OR s| d 
GDC_SHADOW_ROP_NOR (S| d) 
GDC_SHADOW_ROP_EQUIV \(s “d) 
GDC_SHADOW_ROP_INVERT Id 


GDC_SHADOW_ROP_OR_REVERSE s| !d 
GDC_SHADOW_ROP_COPY_INVERTED !s 
GDC_SHADOW_ROP_OR_INVERTED  !s| d 
GDC_SHADOW_ROP_NAND \(s & d) 
GDC_SHADOW_ROP_SET All bits are set to 1 


s:drawing value 
d:destination value 


MB 86290 Series 
Graphics Driver Users Manual 
115 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


Return value 


Error code 


Description 


[When the “Graphics Controller” is MB86293 or later, following 
functions are available] 
[For border] 


GDC_BORDER_ROP_CLEAR All bits are set to 0 
GDC_BORDER_ROP_AND s&d 
GDC_BORDER_ROP_AND_REVERSE- s&!d 
GDC_BORDER_ROP_COPY s 

GDC _| BORDER_ “ROP “AND | INVERTED 's&d 
GDC_BORDER_ROP_NOP d 
GDC _| BORDER | ROP “XOR s“d 
GDC_BORDER_ROP_OR s| d 
GDC_BORDER_ROP_NOR \s| d) 
GDC_BORDER_ ROP _| _EQUIV \s “d) 
GDC_BORDER_ROP_INVERT Id 
GDC_BORDER_ROP ~OR_ REVERSE s| !d 


GDC_ BORDER _ ROP ~COPY_ INVERTED !s 
GDC_BORDER_ROP_OR _| INVERTED Is| d 
GDC_BORDER_ROP_ NAND \s & d) 
GDC_BORDER_ROP SET All bits are set to 1 


[For non top-left primitive] 


GDC_NON_TOPLEFT_ROP_CLEAR All bits are set 
to 0 

GDC_NON_TOPLEFT_ROP_AND s&d 

GDC_NON_TOPLEFT_ROP_AND_REVERSE s& Id 

GDC_NON_TOPLEFT_ROP_COPY S 

GDC_NON_TOPLEFT_ROP_AND_INVERTED Is&d 

GDC_NON_TOPLEFT_ROP_NOP d 

GDC_NON_TOPLEFT_ROP -XOR s“d 

GDC_NON_TOPLEFT_ROP_OR s|d 

GDC_NON_TOPLEFT_ROP_NOR s| d) 

GDC_NON_TOPLEFT_ROP “EQUIV \s “d) 

GDC _| “NON _TOPLEFT_ROP_INVERT Id 

GDC _| NON_TOPLEFT_ROP_ “OR. REVERSE s| !d 

GDC_ NON_TOPLEFT_ROP ~COPY_ INVERTED - !s 

GDC _| “NON _TOPLEFT_ROP_OR | INVERTED Is| d 

GDC_ NON _TOPLEFT_ ROP _| NAND \s & d) 

GDC _ NON_TOPLEFT_ROP “SET All bits are set 
tol 


s:drawing value 
d:destination value 


GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets logical arithmetic type. 

This operation is performed between the pixel color to be drawn and current pixel 
color in the drawing frame. Result of this operation is to be drawn to the drawing 
frame. 

This operation is applicable only when drawing attribute of line or surface or BitBIt's 
GDC_BLEND_ROP option of GDC_BLEND_MODE is selected. 

This command can be used by all “Graphics Controller”. 

Keep in mind that it will perform logical arithmetic in the shadows when the 
primitive between shadow composition overlaps with the shadow, since the same 
logical arithmetic mode as the shadow of a line and the primitive between shadow 


composition is applied if the logical arithmetic mode of the shadow is set up. 
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6.10 Attribute Control Commands for Object Coordinates 


6.10.1 GdcGeoSetAttrMisc [Sets miscellaneous attribute] 


Format int GdcGeoSetAttrMisc (GDC_ULONG target, GDC_ULONG param) 
Parameter target Geometry attribute 
GDC_GEO_VTX_COL Enable/disable vertex color in smooth 
shading 
GDC_GEO_ VTX_Z Enable/disable z coordinates of vertex in Z 


value comparison 

GDC_GEO_VTX_ST Enable/disable ST coordinates of vertex in 
texture mapping 

GDC_GEO_IN_FORMAT __ Input format 


param = Parameter corresponding to target (*1) 


Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 
Description Sets miscellaneous attribute for object coordinates. 
Attributes and parameters for them are described below. 


This command is for MB86291 or later. 
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(*1) Miscellaneous attribute (target) and parameter (param) corresponding to each miscellaneous 
attribute is shown below. 


[Explanatory notes] 


Miscellaneous attribute Description of miscellaneous attribute 
Parameter 1 that can set Description of parameter 1 
Parameter 2 that can set Description of parameter 2 
GDC_GEO_VTX_COL Specifies when using color of vertex. 


Smooth shading mode (GDC_SHADE_SMOOTH) should 
also set smooth shading by the shade mode 
(GDC_SHADE_MODE) of the GdcSetAttrSurf command. 


GDC_ENABLE Enables vertex color. 
GDC_DISABLE Disables vertex color. 
GDC_GEO_VTX_Z Specifies when using z coordinates of vertex. 
GDC_ENABLE Enables Z value. 
GDC_DISABLE Disables Z value. 
GDC_GEO_VTX_ST Specifies when using texture coordinates of vertex. 


Texture mapping (GDC_SELECT_TEXTURE) should also 
set texture mapping by the texture mapping mode 
(GDC_TEXTURE_SELECT) of the GdcSetAttrSurf 


command. 
GDC_ENABLE Enables ST (texture coordinates). 
GDC_DISABLE Disables ST (texture coordinates). 
GDC_GEO_IN_FORMAT Specifies input format. 


GDC_GEO_FLOAT_INPUT Floating-point format. 
GDC_GEO_FIXED_INPUT Fixed-point format. 
GDC_GEO_INT_INPUT Integer format. 
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6.10.2 GdcGeoSetAttrLine [Sets line drawing attribute for object coordinates] 


Format int GdcGeoSetAttrLine (GDC_ULONG target, GDC_ULONG param) 


Parameter target Line drawing attribute 
GDC_GEO_THICK_LINE_CORRECT Sets correction mode of 
thick line connection 
GDC_GEO BROKEN_LINE_CORRECT _ Sets correction mode of 
broken line pattern 
GDC_GEO_BROKEN_LINE_CORRECT _ Sets thenumber of broken 
_LENGTH line pattern address 
fixation pixel 
GDC_GEO_UNIFORM_LINE_WIDTH Sets uniform mode of line 
width 
GDC_GEO_THICK_LINE_VERTICAL _ Sets thick/broken line 
vertical mode 
GDC_GEO_BORDER LINE Sets drawing mode of 
border primitive 
GDC_GEO_SHADOW_MODE Sets drawing mode of 


shadow primitive 


param Parameter corresponding to target (*1) 
Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 
Description Sets line drawing attribute in object coordinates. 

The combination of line drawing attribute is shown in the table 6.10.2. 


This command is for MB86293 or later. 


(*1) Line drawing attribute (target) and parameter (param) corresponding to each line drawing attribute 
is shown below. 


[Explanatory notes] 


Line drawing attribute Description of line drawing attribute 
Parameter 1 that can set Description of parameter 1 
Parameter 2 that can set Description of parameter 2 
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GDC_GEO THICK_LINE_CORRECT 
GDC_ENABLE 
GDC_DISABLE 


GDC_GEO BROKEN _LINE_CORRECT 
GDC_ENABLE 


GDC_DISABLE 


GDC_GEO_ BROKEN _LINE_CORRECT_ 
LENGTH 


0-32 


GDC_GEO_UNIFORM_LINE_WIDTH 
GDC_ENABLE 
GDC_DISABLE 


GDC_GEO_THICK_LINE_VERTICAL 
GDC_ENABLE 


GDC_DISABLE 


GDC_GEO BORDER LINE 
GDC_ENABLE 
GDC_DISABLE 


GDC_GEO SHADOW_MODE 
GDC_ENABLE 
GDC_DISABLE 


Sets thick line connection correct mode. 
Enables thick line connection correct. 


Disables thick line connection correct. 


Sets broken line connection correct mode. 

Refer to the same broken line pattern with front and back 
number pixel of broken line connection part (“broken line 
pattern address fixation mode”). Number of pixel is set by 
GDC_GEO BROKEN _LINE_CORRECT LENGTH. 


Not correct broken line pattern (Default). 


Sets the number of broken line pattern address fixation 
pixel. A recommended value is the same as line width. 
This parameter is available when the correction mode of 
broken line pattern is “broken line pattern address 
fixation mode”. 


Number of pixel (default is 0). 


Sets uniform mode of line width. 
Enables uniform of line width. 


Disables uniform of line width. 


Sets thick/broken line vertical mode. 

Draws perpendicular section of thick/broken line to an 
ideal line. 

Draws perpendicular section of thick/broken line to a base 


axis. 


Sets drawing mode of border primitive. 
Draws border primitive. 


Not draw border primitive. 


Sets drawing mode of shadow primitive. 
Draws shadow primitive. 


Not draw shadow primitive. 
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Table.6.10.2 Combination of the line drawing attribute 


GDC_GEO_THICK_LINE_VERTICAL 

GDC_ENABLE GDC_DISABLE 
GDC_GEO_THICK_LINE_CORRECT DC_ENAB OK NG 
DC_DISAB OK OK 
GDC_GEO_UNIFORM_LINE_WIDTH | GDC_ENAB OK NG 
DC_DISAB NG OK 
GDC_GEO_BORDER_LINE DC_ENABLE OK NG 
DC_DISAB OK OK 
GDC_GEO_SHADOW_MODE DC_ENAB OK NG 
DC_DISAB OK OK 


OK: Possible 


NG: Impossible (not supported) 
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6.10.3 GdcGeoSetAttrSurf [Sets surface drawing § attribute for object 
coordinates] 


Format int GdcGeoSetAttrSurf (GDC_ULONG target, GDC_ULONG param) 
Parameter target Surface drawing attribute 
GDC_GEO_ FACE_CULL Enable/disable culling back face 
of triangle 
GDC_GEO_ FACE_INVERT Specify direction of surface of 
triangle 


[When the “Graphics Controller” is MB86293 or later, following 
functions are available] 


GDC_GEO_NON_TOPLEFT Sets drawing algorithm 
GDC_GEO_ SHADOW_MODE Sets drawing mode of shadow 


primitive 
param Parameter corresponding to target (*1) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_INVALID_ATTRIBUTE (Invalid attribute is specified) 
Description Sets surface drawing attribute in object coordinates. 
Culling back face of triangle and specify direction of surface of triangle doesn’t affect 
polygons (GDC_POLYGON). 
Attributes for surface drawing and parameters for them are described below. 


This command is for MB86291 or later. 


MB 86290 Series 
Graphics Driver Users Manual 
122 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


(*1) Surface drawing attribute (target) and parameter (param) corresponding to each surface drawing 
attribute is shown below. 


[Explanatory notes] 


Surface drawing attribute Description of surface drawing attribute 
Parameter 1 that can set Description of parameter 1 
Parameter 2 that can set Description of parameter 2 
GDC_GEO_FACE_CULL Specifies culling back face of triangle. 
GDC_ENABLE Enables culling back face of triangle. 
GDC_DISABLE Disables culling back face of triangle. 
GDC_GEO_FACE_INVERT Specifies direction of surface of triangle. 


Counterdockwise surface is front facing by default. 


GDC_ENABLE Invert direction of surface from default. 

GDC_DISABLE Direction of surface is default. 
GDC_GEO_NON_TOPLEFT Sets drawing algorithm (for MB86293 or later). 

GDC_ENABLE Non top-left applying rule is used. 

GDC_DISABLE Non top-left applying rule is not used. 
GDC_GEO_ SHADOW_MODE Sets drawing mode of shadow primitive (for MB86293 or 

later). 
GDC_ENABLE Draws shadow primitive. 
GDC_DISABLE Not draw shadow primitive. 
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6.10.4 GdcGeoLoadMatrix[f] [Sets matrix] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoL oadMatrix (GDC_FIXED32 *ptM atrix) 


int GdcGeoL oadM atrixf (GDC_SFLOAT *ptMatrix) 


ptMatrix A pointer to an array {m1, m2, m3, ..., m16} which corresponds to 
the 4 x 4 matrix M such as, 
m1 m5 m9 m13 
m2 m6 m10 m14 
M 
m3 m7 mll1 m15 
m4 ms m12 m16 
GDC_TRUE Complete 
GDC_FALSE _ Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Sets a 4 x 4 matrix that transforms an object coordinates to a dip coordinate. 


Each element in the matrix is put in the following order. 


m1 m5 m9 m13 
m2 m6 m10 m14 
M= m3 m7 mils mis 
m4 ms m12 m16 


Elements (m4 ,m8, m12, m16) in the matrix specify whether the projection type is 
orthographic or perspective. Therefore the projection type is set automatically by the 
result of their values. 

If (m4 ,m8, m12, m16) = (0,0,0,1), then orthographic projection. 

Else if (m4 ,m8, m12, m16) !=(0,0,0,1) then perspective projection. 

This command is for MB86291 or later. 
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6.10.5 GdcGeoNdcDcViewportCoef[f] [Sets coefficients of NdcDc transformation 


for XY] 
Format int GdcGeoNdcDcViewportCoef (GDC_FI XED32 scalex, GDC_FI XED32 offsetx, 
GDC_FIXED32 scaley, GDC_FIXED32 offsety) 
int GdcGeoNdcDcViewportCoeff (GDC_SFLOAT scalex, GDC_SFLOAT offsetx, 
GDC_SFLOAT scaley, GDC_SFLOAT offsety) 
Parameter scalex Magnification of x 
offsetx Offset of x 
scaley Magnification of y 
offsety Offset of y 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets the magnifications and offsets of x, y that is used for transforming Normalized 


Device Coordinates (NDC) to Device Coordinates (DC). 


This command is for MB86291 or later. 


6.10.6 GdcGeoNdcDcDepthCoef{[f] [Sets coefficients of NdcDc transformation 


for Z] 
Format int GdcGeoN dcDcDepthCoef (GDC_FIXED32 scalez, GDC_FIXED32 offsetz) 
int GdcGeoNdcDcDepthCoeff (GDC_SFLOAT scalez, GDC_SFLOAT offsetz) 
Parameter scalez Magnification of z 


offsetz Offset of z 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets the magnification and offset of z that is used for transforming Normalized Device 
Coordinates (NDC) to Device Coordinates (DC). 
This command is for MB86291 or later. 
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6.10.7 GdcGeoViewVolumeXYClip[f] [Sets view volume boundary for XY] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoViewVolumexXY Clip (GDC_FIXED32 xmin, GDC_FIXED32 xmax, 
GDC_FIXED32 ymin, GDC_FIXED32 ymax) 

int GdcGeoViewVolumeXY Clipf (GDC_SFLOAT xmin, GDC_SFLOAT xmax, 
GDC_SFLOAT ymin, GDC_SFLOAT ymax) 


xmin Minimum dip value of x 

xmax Maximum dip value of x 

ymin Minimum clip value of y 

ymax Maximum dip value of y 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Sets the view volume boundary in the clip coordinates for x, y. 


This command is for MB86291 or later. 


6.10.8 GdcGeoViewVolumeZClip[f] [Sets view volume boundary for Z] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoViewVolumeZClip (GDC_FIXED32 zmin, GDC_FI XED32 zmax) 
int GdcGeoViewVolumeZClipf (GDC_SFLOAT zmin, GDC_SFLOAT zmax) 


zmin Minimum clip value of z 

zmax Maximum clip value of z 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Sets the view volume boundary in the dip coordinates for z. 


This command is for MB86291 or later. 
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6.10.9 GdcGeoViewVolumeWminClip[f] [Sets view volume boundary for w] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoViewVolumeWminClip (GDC_FIXED32 wmin) 
int GdcGeoViewVolumeWminClipf (GDC_SFLOAT wmin) 


wmin Minimum clip value of w 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets the view volume boundary in the clip coordinates for w. 

As the front clip face (zmin) closes with the viewpoint limitlessly, w also 
approximates to zero limitlessly. 

Since w is used to calculate 1/w internally, wmin must be the one that does not occur 
overflow in division. 

w has only minimum value. wmin is not minus value. 


This command is for MB86291 or later. 
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6.10.10 GdcGeoSetLogOutBase [Sets base address for log output of device 
coordinates] 


Format int GdcGeoSetLogOutBase (GDC_ULONG adrs) 


Parameter adrs Base address for log output of device coordinates 
(specified by offset address from top of the graphics memory) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets base address for log output of device coordinates. 
“adrs” must be specified by offset address from top of the graphics memory. 


Log format consists of packed number of x and y coordinates of vertex (refer to figure 


6.10.10). 

bit 

31 30 29 28 | 27 16 | 151413 12 | 11 0) 
0 0 0 S) y 0 0 0 S) x 
S:signed bit 


y:y coordinates values (integer) 
x:x coordinates values (integer) 


All other bits:0 


Figure 6.10.10 Log format of device coordinates 
Log needs 4 byte for every vertex. 
Therefore, memory area must be allocated with size of number of vertex * 4 byte. 
These vertices are specified between the GdcGeoPrimType command and the 
GdcGeoPrimEnd command. 
Address for log output is added by 4 byte whenever one log is outputted. 
If this memory area is used repeatedly, sets the base address for log output again. 
Base address for log output must be set after drawing is finished by “drawing command 
end interruption” or the GdcGetPixelEngienStatus command or the 
GdcGeoGetPixelE ngineStatus command. 


This command is for MB86293 or later. 


MB 86290 Series 
Graphics Driver Users Manual 
128 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.10.11 GdcGeoSetLogOutMode [Sets log output mode of the device coordinates] 


Format void GdcGeoSetL ogOutM ode (GDC_ULONG mode) 


Parameter mode Log output mode of device coordinate 
GDC_GEO_LOGOUT_ENABLE Outputs logs 
GDC_GEO_LOGOUT_DISABLE Not output logs (default) 
GDC_GEO_LOGOUT_ONLY Output logs without drawing 

Return value None 

Description Sets log output mode of device coordinates. Each mode is explained below. 

[GDC_GEO_LOGOUT_ENABLE mode] 
Log is outputted and drawing is executed. 


[GDC_GEO_LOGOUT_DISABLE mode] 
Log is not outputted and drawing is executed. 


[GDC_GEO_LOGOUT_ONLY mode] 
Log is outputted and drawing is not executed. 
This mode is available only when drawing point primitive. 
When “GDC_GEO_LOGOUT_ONLY’” is specified, log is not outputted when primitive 
except point is drawn. 


This command is for MB86293 or later. 
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6.10.12GdcGeoShadowxXyY [Sets xy offset of shadow] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoShadowXY (GDC_ULONG type, GDC_LONG offsetx, GDC_LONG offsety) 


type A kind of primitive 
GDC_GEO_SHADOW Shadow primitive 
GDC_GEO_SHADOW_COMPOSITION Shadow composition 
primitive 
offsetx x offset of shadow (or shadow composition) primitive for body primitive 
offsety y offset of shadow (or shadow composition) primitive for body primitive 


GDC_TRUE Complete 

GDC_FALSE _ Incomplete 

GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets offset of shadow from body. Offset must be specified with pixel unit. 

Shadow composition primitive is the 2nd shadow of lines. In order to hide shadow 
composition primitive, specify same offsets for shadow and shadow composition. 
Shadow composition primitive is not drawn in triangles. 

When offset is positive number, position of x is right side of body, y is lower side of 
body. 

When offset is negative number, position of x is left side of body, y is upper side of body. 
Offset position of shadow form body must be set before drawing shadow primitive. 
Shadow primitive drawing function is available in object coordinates drawing. 


This command is for MB86293 or later. 
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6.10.13GdcGeoOverlapZ [Sets Z value of primitives (body / shadow / border / 
correction in top-left rule non-applicable mode)] 


Format int GdcGeoOverlapZ (GDC_ULONG origin_offset, 
GDC_ULONG non_topleft_offset, 
GDC_ULONG border_offset, 
GDC_ULONG shadow_offset) 


Parameter origin_offset Z value of body primitive 


non_topleft_offset Z value of correction primitive in top-left rule non-applicable 


mode 
border_offset Z value of border primitive 
shadow_ offset Z value of shadow primitive 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 


Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets Z value of body, shadow, border and correction primitive in top-left rule 
non-applicable mode. 
Z value must be set before drawing these primitives. 
When precision of Z value is 8 bits, lower 8 bits of each parameter is effective. 
When precision of Z value is 16 bits, lower 16 bits of each parameter is effective. 


This command is for MB86293 or later. 
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6.10.14GdcGeoShadowColor [Sets color or shadow] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoShadowColor (GDC_COLOR32 color) 


color Sets color of shadow 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets color of shadow. This setting is effective in drawing lines with shadow, triangles 
with shadow, and polygons with shadow. 

Once this command is executed, the same color is continuously applied till this 
command will be executed. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command is for MB86293 or later. 
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6.10.15 GdcGeoShadowBackColor [Sets background color of shadow] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoShadowBackColor (GDC_COLOR3z2 color) 


color Sets background color of shadow 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets background color of shadow. Background color of shadow is effective when drawing 
lines with shadow and it’s shadow is broken line. 

Background color is corresponding to O in bits of broken line pattern when drawing 


shadow as broken line (refer to figure 6.10.15). 


BODY 
_—<$———————— 


SHADOW 


Background color of shadow 


Figure 6.10.15 Relationship between foreground and background color of shadow when 
the broken line pattern is “OxfOfOfOfO” 


Once this command is executed, the same color is continuously applied till this 
command will be executed. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command is for MB86293 or later. 
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6.10.16 GdcGeoBorderColor [Sets color or border] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoBorderColor (GDC_COLOR32 color) 


color Sets color of border 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets color of border. This setting is effective in drawing lines with border. 
Once this command is executed, the same color is continuously applied till this 
command will be executed. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command is for MB86293 or later. 
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6.10.17 GdcGeoBorderBackColor [Sets background color of border] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoBorderBackColor (GDC_COLOR3z2 color) 


color Sets background color of border 
GDC_TRUE Complete 
GDC_FALSE Incomplete 


GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

Sets background color of border. Background color of border is effective when drawing 
lines with border and it’s border is broken line. 

Background color is corresponding to O in bits of broken line pattern when drawing 


border as broken line (refer to figure 6.10.17). 


a 


BORDER 


Background color of border 


Figure 6.10.17 Relationship between foreground and background color of border when 
the broken line pattern is “OxfOfOfOfO” 


Once this command is executed, the same color is continuously applied till this 
command will be executed. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command is for MB86293 or later. 
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6.11 Texture Pattern Control Commands 


6.11.1 GdcTextureMemoryMode [Sets texture memory mode] 


Format int GdcTextureMemoryM ode (GDC_UCHAR mode) 


Parameter mode Texture memory read 


GDC_TEX_MEM_MODE_EXT Read from the graphics 


memory 
GDC_TEX_MEM_MODE_INT Read from internal texture 
memory 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_INVALID_PARAMETER(Invalid parameter is specified) 
Description Sets the source memory to refer texture pattern from, either internal texture memory 
or the graphics memory. 


This command can be used by all “Graphics Controller”. 


6.11.2 GdcTextureLoadint [Loads texture/tile pattern to internal texture memory] 


Format int GdcTextureLoadI nt (GDC_USHORT length, GDC_LPCOL16 IpTexture, 
GDC_ULONG oadrs) 


Parameter length Texture pattern size (pixel unit) 

IpTexture Pointer to refer texture pattern 

oadrs Offset address of the memory texture pattern is stored 
Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_DATA_TOO BIG (Toolarge data) 

Description Loads texture pattern or tile pattern to internal texture memory. 
GDC_COL8 format texture data is assumed to be packed in GDC_COL16 texture 
format. 


This command can be used by all “Graphics Controller”. 
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6.11.3 GdcTextureLoadExt [Loads texture pattern to the graphics memory] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcTextureLoadE xt (GDC_ULONG length, GDC_LPCOL16 I|pTexture, 
GDC_ULONG adrs) 


length Texture pattern size (pixel unit) 

IpTexture Pointer to refer texture pattern 

adrs Offset address of the memory texture pattern is stored 
GDC_TRUE Complete 

GDC_FALSE Incomplete 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

- GDC_ERR_DATA_TOO BIG (Toolarge data) 

Copies texture pattern to the graphics memory. 

Prior to this command execution, size of the texture pattern should be set by the 
GdcT extureDimension command. 

If length is longer than 65536, transfer will not complete successfully. 


This command can be used by all “Graphics Controller”. 


6.11.4 GdcTextureLoadExt8 [Loads 8bpp texture pattern to the graphics 


memory] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcTextureL oadE xt8 (GDC_LPCOL8 IpTexture, GDC_ULONG adrs) 


IpTexture Pointer to refer texture pattern 

adrs Offset address of the memory texture pattern is stored 
GDC_TRUE Complete 

GDC_FALSE Incomplete 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 

- GDC_ERR_DATA_TOO BIG (Too large data) 

Copies 8bpp texture pattern to the graphics memory. 

An offset from the graphics memory top must be set to “adrs”. 

Prior to this command execution, size of the texture pattern should be set by the 
GdcT extureDimension command. 


This command is for MB86293 or later. 
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6.11.5 GdcTextureLoadExt16 [Loads 16bpp texture pattern to the graphics 


memory] 
Format int GdcTextureL oadE xt16 (GDC_LPCOL16 IpTexture, GDC_ULONG adrs) 
Parameter IpTexture Pointer to refer texture pattern 
adrs Offset address of the memory texture pattern is stored 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
- GDC_ERR_DATA_TOO BIG (Toolarge data) 
Description Copies 16bpp texture pattern to the graphics memory. 


An offset from the graphics memory top must be set to “adrs”. 
Prior to this command execution, size of the texture pattern should be set by the 
GdcTextureDimension command. 


This command is for MB86293 or later. 


6.11.6 GdcTextureLoadExt24 [Loads 24bpp texture pattern to the graphics 


memory] 
Format int GdcTextureL oadE xt24 (GDC_LPCOL24 IpTexture, GDC_ULONG adrs) 
Parameter IpTexture Pointer to refer texture pattern 
adrs Offset address of the memory texture pattern is stored 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
- GDC_ERR_DATA_TOO BIG (Toolarge data) 
Description Copies 24bpp texture pattern to the graphics memory. 


An offset from the graphics memory top must be set to “adrs”. 
Prior to this command execution, size of the texture pattern should be set by the 
GdcTextureDimension command. 


This command is for MB86293 or later. 
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6.11.7 GdcTextureLoadinti6Fast [Loads texture pattern to internal texture 


memory] 
Format int GdcTextureL oadI nt16F ast (GDC_LPCOL16 IpTexture, GDC_ULONG adrs) 
Parameter IpTexture Pointer to refer texture pattern 
adrs Offset address of the memory texture pattern is stored 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
- GDC_ERR_DATA_TOO BIG (Toolarge data) 
Description Copies 16bpp texture pattern to internal texture memory. 


An offset from the internal texture memory top must be set to “adrs”. 
Prior to this command execution, size of the texture pattern should be set by the 
GdcT extureDimension command. 


This command is for MB86293 or later. 


6.11.8 GdcTextureLoadExt16Fast [Loads texture pattern to the graphics 


memory] 
Format int GdcTextureL oadE xt16F ast (GDC_LPCOL16 IpT exture, GDC_ULONG adrs) 
Parameter IpTexture Pointer to refer texture pattern 
adrs Offset address of the memory texture pattern is stored 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
- GDC_ERR_DATA_TOO BIG (Toolarge data) 
Description Copies 16bpp texture pattern to internal texture memory. 


An offset from the internal texture memory top must be set to “adrs”. 
Prior to this command execution, size of the texture pattern should be set by the 
GdcT extureDimension command. 


This command is for MB86293 or later. 
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6.11.9 GdcTextureDimension [Sets texture / tile information] 


Format int GdcTextureDimension (GDC_ULONG adrs, GDC_ULONG oaadrs, 
GDC_ULONG w, GDC_ULONG h) 


Parameter adrs Start address of texture/tile pattern 
oadrs Offset 
Ww Pattern data width (power of 2) 
h Pattern data height (power of 2) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_ILLEGAL_DIMENSION (Illegal vertical/horizontal size of pattern data) 
Description Sets following texture information . 
- Start address of texture/tile pattern 
- Offset 
- Pattern data width 
- Pattern data height 
“adrs” and “oadrs” must be specified with suitable value for the stored position of the 


referred pattern according to the table 6.11.9a. 


Table 6.11.9a Values to be specified to “adrs” and “oadrs” 


Stored position of adrs oadrs 


referred pattern 


Internal texture 0 Offset from top address of 


internal texture memory 


Extend texture Start address of texture | 0 
pattern from top 


address of the graphics 


memory 

Internal tile 0 Offset from top address of 
internal texture memory 

Extend tile Base address of stored | Offset from base address of 
area of tile pattern stored area of tile pattern 


[N ote] 
Available destination address of texture/tile pattern is changed according to the 
“Graphics Controller”. 


This command can be used by all “Graphics Controller”. 
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Range of pattern data width and pattern data height according to the “Graphics 


Controller” are shown in the table 6.11.9b. 


Table 6.11.9b Range of pattern data width and pattern data height 


MB86290A/291/292 MB86293 or later 
Internal texture memory 16,32,64 16,32,64 
The graphics memory 16,32,64,128,256 16-4096 (power of 2) 


This command can be used by all “Graphics Controller”. 
However, external tile function is only for MB86293 or later with which internal 


texture memory is not equipped. 
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6.11.10GdcBltTexture [Loads Blt texture to internal texture memory for 
MB86290A] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcBltTexture (GDC_ULONG sadrs, GDC_ULONG sstride, 


sadr 


sstride 


oadrs 


GDC_TRUE 
GDC_FALSE 


GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h, GDC_ULONG oadrs) 


Memory address of the base point of the source drawing frame 
Stride (memory size of horizontal span) of the source drawing 
frame 

x coordinates of the top left vertex of source BIt 

y coordinates of the top left vertex of source BIt 

Horizontal width of the BIt field (pixel unit) 

Vertical height of the BIt field (pixel unit) 

Offset address of destination memory where texture pattern to be 
stored 

Complete 


Incomplete 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_ILLEGAL_DIMENSION (Illegal vertical/horizontal size of pattern data) 


Loads texture pattern from the graphics memory to the internal texture memory. 


This command is only for MB86290A. 


When the “Graphics Controller” is MB86291, GdcGeoBItTexture must be used. 
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6.11.11GdcGeoBltTexture [Loads Blt texture to internal texture memory for 
MB86291 or later] 


Format 


Parameter 


Return value 


Error code 


Description 


int GdcGeoBltTexture (GDC_ULONG sadrs, GDC_ULONG sstride, 


sadr 


sstride 


oadrs 


GDC_TRUE 
GDC_FALSE 


GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h, GDC_ULONG oadrs) 


Memory address of the base point of the source drawing frame 
Stride (memory size of horizontal span) of the source drawing 
frame 

x coordinates of the top left vertex of source BIt 

y coordinates of the top left vertex of source BIt 

Horizontal width of the BIt field (pixel unit) 

Vertical height of the BIt field (pixel unit) 

Offset address of destination memory where texture pattern to be 
stored 

Complete 


Incomplete 


- GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_ILLEGAL_DIMENSION (Illegal vertical/horizontal size of pattern data) 


Loads texture pattern from the graphics memory to the internal texture memory. 


This command is for MB86291 or later. 


When the “Graphics Controller” is MB86290A, GdcBItT exture must be used. 
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6.12 Binary Pattern Drawing Commands 


6.12.1 GdcBitPatternDraw [Draws binary pattern] 


Format int GdcBitPatternDraw (GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h, GDC_LPBINIMAGE IpPattern) 


Parameter x Xx coordinates of the drawing frame when the top left point of 
binary pattern is drawn 
y y coordinates of the drawing frame when the top left point of 


binary pattern is drawn 


Ww Binary pattern data width (pixel unit) 
h Binary pattern data height (pixel unit) 
IpPattern Pointer to binary pattern data 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_DATA_TOO BIG (Toolarge data) 

Description Draws a binary pattern. Foreground color (pixel of binary pattern “1”) is drawn in the 
color applied by the GdcColor command, and background color (pixel of binary pattern 
“O”) is drawn in the color applied the GdcBackColor command. 


This command can be used by all “Graphics Controller”. 
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6.12.2 GdcBitPatternMode [Sets enlarge/shrink mode] 


Format int GdcBitPatternMode (GDC_UCHAR mode) 


Parameter mode Enlarge/shrink mode(GDC_BPSCALE_H and GDC_BPSCALE_V are 


applicable at the same time) 


GDC_BPSCALE_H_EQUIV Horizontal enlarge x1 
GDC_BPSCALE_H_TWICE Horizontal enlarge x2 
GDC_BPSCALE_H_HALF Horizontal enlarge x1/2 
GDC_BPSCALE_V_EQUIV Vertical enlarge x1 
GDC_BPSCALE_V_TWICE Vertical enlarge x2 
GDC_BPSCALE_V_HALF Vertical enlarge x1/2 

Return value GDC_TRUE Complete 

GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets enlarge/shrink mode for binary pattern drawing. 


This command can be used by all “Graphics Controller”. 
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6.13 BLT Commands 


6.13.1 GdcBltCopy [Copies BitBIt pattern in current drawing frame] 


Format int GdcBltCopy (GDC_USHORT x0, GDC_USHORT yo, 
GDC_USHORT x1, GDC_USHORT yl, 
GDC_USHORT w, GDC_USHORT h) 


Parameter x0 x coordinates of the top left vertex of source BIt 
yO y coordinates of the top left vertex of source BIt 
x1 x coordinates of the bottom right vertex of destination 
yl y coordinates of the bottom right vertex of destination 
Ww Horizontal width of the Blt field (pixel unit) 
h Vertical height of the BIt field (pixel unit) 

Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 

Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_ILLEGAL_DIMENSION (Illegal vertical/horizontal size of pattern data) 
Description Draws bitmap pattern to the drawing frame by BIt copy. 
The destination field is current drawing frame in the graphics memory. 


This command can be used by all “Graphics Controller”. 
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6.13.2 GdcBltCopyAlt, GdcBltCopyAltSync [Copies BitBIt pattern between any 
drawing frame] 


Format int GdcBltCopyAlt (GDC_USHORT x0, GDC_USHORT y0, 
GDC_USHORT x1, GDC_USHORT yl, 
GDC_USHORT w, GDC_USHORT h, 
GDC_ULONG sadr, GDC_ULONG sstride, 
GDC_ULONG dadr, GDC_ULONG dstride) 
int GdcBltCopyAltSync (GDC_USHORT x0, GDC_USHORT yo, 

GDC_USHORT x1, GDC_USHORT yl, 
GDC_USHORT w, GDC_USHORT h, 
GDC_ULONG sadr, GDC_ULONG sstride, 
GDC_ULONG dadr, GDC_ULONG dstride) 


Parameter x0 x coordinates of the top left vertex of source BIt 
yO y coordinates of the top left vertex of source BIt 
x1 x coordinates of the top left vertex of destination 
yl y coordinates of the top left vertex of destination 
Ww Horizontal width of the Blt field (pixel unit) 
h Vertical height of the Blt field (pixel unit) 
sadr Memory address of the base point of the source drawing frame 
sstride Stride (memory size of horizontal span ) of the source drawing 
frame 
dadr Memory address of the base point of the destination drawing 
frame 
dstride Stride (memory size of horizontal span) of the destination drawing 
frame 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_ILLEGAL_DIMENSION (Illegal vertical/horizontal size of pattern data) 

Description Draws bit map pattern to the drawing frame by BIt copy Any drawing framein the 
graphics memory is applicable to source and destination. Color mode of source and 
destination must be the same. The GdcBltCopyAltSync command is synchronously 
executed to the vertical blanking interval. Source and destination field must not be 
overlapped to each other. Clipping operation by the GdcDrawClipF rame command is 
not applicable. 


This command can be used by all “Graphics Controller”. 


MB 86290 Series 
Graphics Driver Users Manual 
147 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.13.3 GdcBltDraw [Draws BitBIt pattern] 


Format int GdcBltDraw (GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h, GDC_LPLONG IpRect) 


Parameter x x coordinates of the top left vertex of source BIt 
y y coordinates of the top left vertex of source BIt 
Ww Horizontal width of the Blt field (pixel unit) 
h Vertical height of the BIt field (pixel unit) 
IpRect Pointer to refer the pattern data 

Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 

Error code - GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 


- GDC_ERR_DATA_TOO BIG (Too large data) 

Description Draws bitmap pattern to the drawing frame by BIt copy. Source field is main memory. 
Color mode of the source field is assumed to be the same as that of current drawing 
frame. 

The data format of IpRect is to be the same as that of current drawing frame. 
The maximum size which can draw at once is as follows. 
[MB86290A/291/291A/292] 
- 2“17-3 double words 
[MB86293 or later] 
- 2731-3 double words 


This command can be used by all “Graphics Controller”. 
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6.13.4 GdcBItFill [Fills BitBlt field] 


Format int GdcBItFill (GDC_USHORT x, GDC_USHORT y, 
GDC_USHORT w, GDC_USHORT h) 


Parameter x x coordinates of the top left vertex of source BIt 
y y coordinates of the top left vertex of source BIt 
Ww Horizontal width of the Blt field (pixel unit) 
h Vertical height of the BIt field (pixel unit) 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Fills a BIt field with the foreground color or tile pattern specified by the GdcColor 
command. 


This command can be used by all “Graphics Controller”. 


6.13.5 GdcBltColorTransparent [Sets transparent color of transparent BitBIt] 


Format int GdcBltColorTransparent (GDC_COLOR3z2 color) 
Parameter color Color code treated as transparent color 
Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Sets the transparent color referred when the BIt pattern is copied/drawn in the 


transparent mode. 


The following values are used by color mode. 


- 8 bits color mode : lower 8 bits of “color” 
- 16 bits color mode : lower 16 bits of “color” 
- 24 bits color mode : lower 24 bits of “color” 


This command is for MB86291 or later. 
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6.13.6 GdcBltCopyAltAlpha [Copies BitBIt pattern with alpha blending] 


Format int GdcBltCopyAltAlpha(GDC_USHORT x0, GDC_USHORT yo, 
GDC_USHORT x1, GDC_USHORT yl, 
GDC_USHORT bx, GDC_USHORT by, 
GDC_USHORT w, GDC_USHORT h, 
GDC_ULONG sadr, GDC_ULONG sstride, 
GDC_ULONG bstride) 


Parameter x0 x coordinates of the top left vertex of source BIt 
yO y coordinates of the top left vertex of source BIt 
x1 x coordinates of the top left vertex of destination 
yl y coordinates of the top left vertex of destination 
bx x coordinates of the top left vertex of alpha map area 
by y coordinates of the top left vertex of alpha map area 
Ww Horizontal width of the BIt field (pixel unit) 
h Vertical height of the BIt field (pixel unit) 
sadr Memory address of the base point of the source drawing frame 
sstride Stride (memory size of horizontal span ) of the source drawing frame 
bstride Stride of the alpha map area (pixel unit) 


Return value GDC_TRUE Complete 
GDC_FALSE Incomplete 
Error code GDC_ERR_NOT_READY (“Graphics Driver” is not initialized) 
Description Execute alpha blending with source BIt area and destination area. 
Copies alpha blended area to the x1,y1 coordinates of current drawing frame. 
Source BIt area is specified with sadrs,sstride,x0,y0,w,h and destination BIt area is 
specified with x1,y1. 
Alpha blend coefficient area is specified with bstride, bx, by, w, h and it’s top address 
is specified by the GdcAlphaM apBase command. 
This command is for MB86293 or later. 
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6.14 Video Capture Commands 


Please use a subsequent video capture command (GdcCap*) after initializing a digital video decoder with 


an |2C control command (Gdcl 2C*), when using the digital video decoder connected with an |2C interface. 


For details information, refer to the “Application Note”. 


6.14.1 GdcCapSetVideoCaptureMode [Sets mode of video capture] 


Format void GdcCapSetVideoCaptureM ode (GDC_ULONG made) 


Parameter mode Sets modes of video capture. The value is set to VCM (Video Capture 


Mode) register as it is. For details information about VCM register, refer to 


the “Graphics Controller” hardware specifications of using. 


Macros representing each mode are prepared. These can be used as the need 


arises. 


Sets each mode by combining in the table 6.14.1 macros. 


Table 6.14.1 Video capture mode control macro list 


Macros 


Meaning 


GDC_CAP_START 


Starts capturing 


GDC_CAP_STOP 


Stops capturing 


GDC_CAP_ENABLE_V_INTERPOLATION 


Performs the interpolation 


of perpendicular direction 


GDC_CAP_DISABLE_V_INTERPOLATION 


NOT perform the 
interpolation of 


perpendicular direction 


GDC_CAP_NTSC 


Video=NTSC 


GDC_CAP_PAL 


Video=PAL 


Return value None 


Description Sets a value to VCM (Video Capture Mode) register, and sets video capture mode. 


This command is for MB86291 or later. 


MB 86290 Series 
Graphics Driver Users Manual 
151 


Copyright(Q)F UJ ITSU LIMITED 1999-2003 


6.14.2 GdcCapGetErrorStatus [Gets error status of video capture] 


Format GDC_ULONG GdcCapGetErrorStatus(void) 


Parameter None 
Return value — Video Capture Status (VCS) register in the following format: 


31 ated 4 3 2 1 0 


bit 0-4: Error status Yes =except 00000, No =all 0 
All other bits:unsetled 


Figure 6.14.2 Error status of video capture 


Description Reads VCS (Video Capture Status) register and returns error status. 


This command is for MB86291 or later. 


6.14.3 GdcCapClearErrorStatus [Clears error status of video capture] 


Format void GdcCapClearErrorStatus(void) 


Parameter None 
Return value None 
Description Sets 0 to VCS (Video Capture Status) register and clears error status. 


This command is for MB86291 or later. 
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6.14.4 GdcCapSetVideoCaptureBuffer [Sets video capture buffer] 


Format 


Parameter 


Return value 


Description 


void GdcCapSetVideoCaptureBuffer (GDC_ULONG saddr, GDC_ULONG eaddr, 
GDC_ULONG stride) 


saddr Specifies the start address of the video capture buffer by offset value 
from the graphics memory 

eaddr Specifies the end address +1 of the video capture buffer by offset value 
from the graphics memory 

stride Sets width of memory (stride) for video capture buffer in blocks of 64 
byte 

None 

Sets video capture buffer. 

The start address needs to bein a 16 byte boundary. 

Please specify the end address +1 of the video capture buffer as the end address. 

The video capture buffer size need a size which is a part for the picture to take at 

least. 


This command is for MB86291 or later. 


6.14.5 GdcCapSetlmageArea [Sets range of image] 


Format 


Parameter 


Return value 


Description 


void GdcCapSetl mageArea (GDC_USHORT x0, GDC_USHORT y0, 
GDC_USHORT x1, GDC_USHORT yl) 


x0 The upper left x coordinates of the picture 
yO The upper left y coordinates of the picture 
x1 The lower right x coordinates of the picture 
yl The lower right y coordinates of the picture 
None 


Sets the range for the image to be written to the video capture buffer. 

The picture of the range of (x0,y0) and (x1,y1) which are the starting point (0,0) of the 
upper left of the input picture is written to buffer. 

Please set coordinates x0<x1 and yO<y1 to specify the range of the picture. 


This command is for MB86291 or later. 
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6.14.6 GdcCapSetDisplaySize [Sets dimension of captured image for scaling] 


Format 


Parameter 


Return value 


Error code 


Description 


GDC_BOOL GdcCapSetDisplaySize (GDC_ULONG w, GDC_ULONG h) 


WwW Width of scaled image (in pixels, range 1-4096) 

h Height of scaled image (in pixels, range 1-4096) 

GDC_TRUE Complete 

GDC_FALSE Incomplete 

- GDC_ERR_ILLEGAL_CAPTURE_SIZE (Illegal video capture size has specified) 

- GDC_ERR_ILLEGAL_CAPTURE_SCALE (Illegal video capture scale has specified) 

Sets dimension of the captured image which is scaled. 

Specify dimension of original captured image by GdcCapSetl mageArea command before 
the calling of this command. 

If O is specified for w or h, sets error code GDC_ERR_ILLEGAL_CAPTURE_SIZE, and 
returns GDC_FALSE. 

When the value from which the width or the height of captured image after scaling 
becomes 2048 or more times is set up, sets error code 
GDC_ERR_ILLEGAL_CAPTURE_SCALE and returns GDC_FALSE. 

This command is only for MB86294. 


6.14.7 GdcCapGetImageAddress [Gets address of captured image] 


Format 


Parameter 
Return value 


Description 


GDC_ULONG *GdcCapGetl mageAddress (void) 


None 
Top address of captured image (offset address from the top of Graphics Memory) 
Returns the top address of the captured image, which is the value of register L1DA. 
Before the calling of this command, Stop the video’ capturing § by 
GdcCapSetVideoCaptureMode command as shown below, because the top address of 
captured image is progressed while the video capture is running. 
GDC_ULONG *adrs; 
GdcCapSetVideoCaptureM ode(GDC_CAP_STOP); /* Stops the video capturing */ 
adrs =GdcCapGetl mageAddress(); /* Gets address of captured image */ 
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6.14.8 GdcCapSetWindowMode [Sets W(L1) layer mode] 


Format 


Parameter 


Return value 


Description 


void GdcCapSetWindowM ode (GDC_ULONG format, GDC_ULONG mode,) 


format Sets color format of W(L1) layer 


Sets YC modes when using video capture 


GDC_CAP_RGB_MODE RGB mode (default) 
GDC_CAP_YC_MODE YC mode 
mode Sets whether W(L1) layer is used as a normal display layer or a video 
capture 
GDC_CAP_NORMAL_MODE Normal mode (default) 
GDC_CAP_CAPTURE_MODE Capture mode 


None 

Sets mode of W(L1) layer. When using video capture, be sure to set mode. 

Before execute this command, sets attribute of W layer by the GdcDispDimension 
command beforehand. Color mode supports only 16 bits mode. 


This command is for MB86291 or later. 
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6.14.9 GdcCapSetVideoCaptureScale [Sets scale of video capture] 


Format 


Parameter 


Return value 


Description 


void GdcCapSetVideoCaptureScale (GDC_FIXED_SCALE hscale, 
GDC_FIXED_SCALE vscale) 


hscale Horizontal scaling rate (default =0x0800) 
vscale Vertical scaling rate (default =0x0800) 
None 


Sets scales for reducing video capture. 
Sets horizontal scaling rate (hscale) which is cast to “GDC_FIXED_SCALE” type. 
Sets vertical scaling rate(vscale) which is cast to “GDC_FlXED_SCALE” type. 
Specify hscale for horizontal scaling rate which the value divided number of 
horizontal pixels of captured image by scaled image's one. vscale is vertical scaling 
rate which the value divided number of vertical pixels of captured image by scaled 
image's one. 
The type GDC_FIXED_SCALE is fixed point format which consists of 5 bits interger 
and 11 bits fraction. The range of the value is as follows. 
Oxffff (1/31.99951171875) - Ox0800 (1.0) 
Initial value of hscale and vscale is Ox0800 (no scaling) respectively. 
Examples of calculation of scaling rate is shown below. 
[Example of calculation of scaling rate] 
(1)When the image of size 720*576 is reduced to the size 648*490, scaling rate is 
calculated as below. 
--Reduction of horizontal direction 
720pixel to 648pixel 
720/648=1.111 
1.111*2048=2275 (expressed in hexadecimal is Ox08e3) 
--Reduction of vertical direction 
576line to 490line 
576/490=1.176 
1.176*2048=2275 (expressed in hexadecimal is 0x0968) 
--A value to be set to “hscale” is “Ox08e3”. 


--A value to be set to “vscale” is “Ox0968”. 


(2)When 1/n times, scaling rate is calculated as below. 
--hscale =n * 2048 
--vscale =n * 2048 


This command is for MB86291/86292/86293. 
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6.14.10 GdcCapSetAttrMisc [Sets attribute of video capture] 


Format int GdcCapSetAttrMisc (GDC_ULONG target, GDC_ULONG param) 
Parameter target Video capture attribute 
GDC_CAP_ODD_MODE Odd number mode 
GDC_CAP_CNV_MODE Non-interlace conversion mode 
param Parameter corresponding to target (*1) 
Return value GDC_TRUE Complete 
GDC_FALSE _ Incomplete 


Description Sets attribute of video capture. 
The attribute of video capture and the parameter are shown below. 


This command is for MB86291 or later. 


(*1) Video capture attribute (target) and parameter (param) corresponding to each video capture 


attributes are shown below. 


[Explanatory notes] 
Video capture attribute 
Parameter 1 that can set 
Parameter 2 that can set 


GDC_CAP_ODD_MODE 
GDC_CAP_EVEN_AND_ODD MODE 


GDC_CAP_ODD_ONLY_MODE 


GDC_CAP_CNV_MODE 


GDC_CAP_CNV_BOB_MODE 
GDC_CAP_CNV_WEAVE_MODE 


(*2)BOB mode 


Description of video capture attributes 
Description of parameter 1 
Description of parameter 2 


Specifies the capture method. 


Captures both the odd number and the even 
number fields (default). 
Captures only the odd number field. 


Specifies the non-interlace conversion mode of the 
picture which is captured. 

BOB mode (*2). 

WEAVE mode (default) (*3). 


‘The mode is a frame which is the even field of the raster is averaged 


interpolation then it is added to the odd field. 


(*3)WEAVE mode 


video capture buffer. 


‘The mode is a frame which is the odd field and the even field merge on the 
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6.14.11 GdcCapSetinputDataCountNTSC [Sets the video capture buffer for NTSC] 


Format 


Parameter 


Return value 


Description 


void GdcCapSet!l nputDataCountNTSC (GDC_ULONG blank_data, 
GDC_ULONG valid_data) 
blank_data The horizontal blanking interval is specified by the dot clock cycle 
number 
valid_data The data number of the term of validity is specified by the dot dock 
cycle number 
None 
Sets the input video stream number at the time of NTSC format. 
This command is used to detect an error occurred. When the input data is not same as 
the value set up by this command, an error occurs. The video capture status becomes 
the value other than zero at this time. 
Also, capturing is continued when the error occurred. 


This command is for MB86291 or later. 


6.14.12 GdcCapSetInputDataCountPAL [Sets the video capture buffer for PAL] 


Format 


Parameter 


Return value 


Description 


void GdcCapSetl nputDataCountPAL (GDC_ULONG blank_data, 
GDC_ULONG valid_data) 
blank_data The horizontal blanking interval is specified by the dot clock cycle 
number 
valid_data The data number of the term of validity is specified by the dot dock 
cyde number 
None 
Sets the input video stream number at the time of PAL format. 
This command is used to detect an error occurred. When the input data is not same as 
the value set up by this command, an error occurs. The video capture status becomes 
the value other than zero at this time. 
Also, capturing is continued when the error occurred. 


This command is for MB86291 or later. 
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6.14.13 GdcCapSetLPFMode [Sets low pass filter mode] 


Format void GdcCapSetLPF Mode (GDC_ULONG vlpf_y, GDC_ULONG vIpf_c, 
GDC_ULONG hipf_y, GDC_ULONG hipf_c) 


Parameter vipf_y The vertical LPF coefficient code for luminosity signals (0-2) 
vipf_c The vertical LPF coefficient code for different color signals (0-2) 
hipf_y The horizontal LPF coefficient code for luminosity signals (0-3) 
hipf_c The horizontal LPF coefficient code for different color signals (0-3) 


Return value None 

Description The mode (formula) of the low pass filter at the time of a video capture is set up. 
One of the following of coefficients can be specified in vipf_y of an argument, and 
vipf_c. When a coefficient is 0, it outputs as it is, without covering a low pass filter. 


Theinitial value of vipf_y and vipf_care 0. 


Table 6.14.11a Low pass filter formula (for vipf_y and vipf_c) 


Coefficient Low pass filter formula 
0) ylij] =xtij] 
1 ylij] =xfi,j-11/4 +xfi,j/2 +xli,j+1/4 
2 yLij] =xti,j-1]*3/16 +xfi,j 5/8 +xfi,j-+1}*3/16 
where 


[i,j] : input pixel value at i-th column and j-th raster 


yli,j] : output pixel value at i-th column and j-th raster 


One of the following of coefficients can be specified in hlpf_y of an argument, and 
hlpf_c. When a coefficient is 0, it outputs as it is, without covering a low pass filter. 


Theinitial value of hlpf_y and hipf_care 0. 


Table 6.14.11b Low pass filter formula (for hlpf_y and hipf_c) 


Coefficient Low pass filter formula 

0) ylij] =xij) 

1 vii, j] =xfi-1,j/4 +xfijV/2 +xfi+1j/4 

2 yii,j] =xfi-1,j 3/16 +xli,j 5/8 +xfi+1,j}*3/16 

3 YLi,j] =xi-2,j1*3/32 +x{i-1,j/4 +x{i,j]*5/16 
+x[i +L jl/4 +xli+2,j1*3/32 


where 
x[i,j] : input pixel value at i-th column and j-th raster 


yli,j] : output pixel value at i-th column and j-th raster 


This command is for MB86291 or later. 
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6.15 I?7C Control Commands 


6.15.1 Gdcl2CGetBusStatus [Gets I?C bus status] 


Format 


Parameter 


Return value 


Description 


GDC_ULONG Gdcl2CGetBusStatus (void) 


None 


12C bus status in the following format (value of BSR register): 


bit31 --- 7 6 5 4 3 2 1 0 


bit7:Detects START/STOP condition 
0:STOP condition 


1:START condition (The bus is in use) 
bit6:Detects repeated START condition 
0:Repeated START condition was not detected 
1:START condition was detected again while bus is in use 
bit5:I ndicates Arbitration lost 
0:Arbitration lost was not detected 
1:Arbitration lost occurred during master transmission 
bit4:Status of Acknowledge 
0:No acknowledge 
1:Acknowledge 
bit3:Status of data transfer 
0:Receiving status 
1:Transmitting status 
bit2:Detects addressing 
0:Addressing was not performed in a slave mode 
1:Addressing was performed in a slave mode 
bitl:Detects “General call address (00h)” 
0:’General call address(O00h)” was not received in a slave mode 
1:"General call address(00h)” was received in a slave mode 
bitO:Detects the first byte 
0:Received data is not the 1*t byte 
1:Receiverd data is the 1st byte (address data) 
All other bits: unsettled 


Figure 6.15.1 12C bus status 


Reads BSR (Bus Status Register) and returns |2C bus status. 
This command is for MB86291S or MB86292S. 
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6.15.2 Gdcl2CSetBusControl [Controls I?C bus] 


Format void Gdcl2CSetBusControl (GDC_UCHAR param) 
Return value param The parameter for |2C bus control (the following format) 
bit 7 6 5 4 3 2 1 0 
x x x x x x x x 


bit7:Flag bit for request of bus error interruption 
0:Clears a request flag of bus error interruption 
1:Dontt care 
bit6:Permits bus error interruption 
0:Prohibition of bus error interruption 
1:Permission of bus error interruption 
bit5:Generates START condition 
0:Don't care 
1:START condition is generated again at the time of master transmission 
bit4:Selects master/slave mode 
0:Becomes a slave mode after generation of STOP condition and completing 
transfer 
1:Becomes a master mode, generates START condition and starts transfer 
bit3:Permits generation of acknowledge at the time of data reception 
0:Acknowledge is not generated 
1:Acknowledge is generated 
bit2: Permits generation of acknowledge at the time of “General call address(00h)” 
reception 
0: Acknowledge is not generated 
1: Acknowledge is generated 
bit1:Permits interruption 
0:Prohibition of interrupt 
1:Permission of interrupt 
bitO:F lag bit for request of interruption for transfer end 
0:Clears the flag 
1:Dontt care 


Figure 6.15.2 The parameter for |2C bus control format 


Return value None 
Description Controls |2C bus by value of parameter for |12C bus control. 


This command is for MB86291S or MB86292S. 
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6.15.3 Gdcl2CGetBusControlStatus [Gets I?C bus control status] 


Format GDC_ULONG Gdcl2CGetBusControlStatus (void) 


Parameter None 


Return value —_|2C bus control status in the following format (value of BCR register): 


bit 7 6 5 4 3 2 1 0 


bit7: Flag bit for request of bus error interruption 
0:A bus error was not detected 
1:Invalid START condition or STOP condition was detected while data 
transfer 
bit6: Permission of bus error interruption 
0:Prohibition of bus error interruption 
1:Permission of bus error interruption 
bit5: Unsettled 
bit4: Master / slave mode 
0:Slave 
1:Master 
bit3: Permission of generating acknowledge at the time of data reception 
0:Acknowledge is not generated 
1:Acknowledge is generated 
bit2: Permission of generating acknowledge at the time of “General call address 
(OOh)” reception 
0:Acknowledge is not generated 
1:Acknowledge is generated 
bitl: Permission of interruption 
0:Prohibition of interrupt 
1:Permission of interrupt 
bitO: Flag bit for request of interruption for transfer end 
0:The transfer is not ended 


1:It is set when 1 byte transfer including the acknowledge bit is completed and 
it corresponds to the following conditions 
- It is a bus master 
- It is an addressed slave 
- It received “General call address (0Oh)” 
- It was going to generate START condition while other systems by which 


arbitration lost happened used the bus 


Figure 6.15.3 12C bus control status 


Description Reads BCR (Bus Control Register) and returns |2C bus control status. 


This command is for MB86291S or MB86292S. 
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6.15.4 Gdcl2CSetClock [Sets IC clock] 


Format void Gdd 2CSetClock (GDC_UCHAR param) 
Parameter param Parameter for setup of |2C clock (*1) (the following format) 
bit 7 6 5 4 3 2 1 0 
0 x x x x x x x 


bit6:Selects standard-mode / high-speed-mode 
0:Standard-mode 
1:High-speed-mode 

bit5:Permits |2C operation 
0:Prohibition of operation 
1:Permission of operation 

bit4-0:F requency of a transfer clock 
00000-11111 

All other bits: 0 


Table 6.15.4 |2C dock parameter format 
(*1) For details information about |2C clock, refer to the chapter of the “clock control 
register” of “l2C Interface specification”. 
Return value None 
Description Writes parameter to CCR (Clock Control Register) and sets transfer clock. 


This command is for MB86291S or MB86292S. 
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6.15.5 Gdcl2CGetClock [Gets I?C clock control status] 


Format GDC_ULONG Gddl 2CGetClock (void) 


Parameter None 


Return value — 1|2C clock (*1) control status in the following format (value of CCR register): 


bit31  ..  bit7 6 5 4 3 2 1 0 


0) sfc 1 4 4 4 4 Xx Xx Xx 


bit7:Not used (read value is always 1) 
bit6:Selects standard-mode / high-speed-mode 
0:Standard-mode 
1:High-speed-mode 
bit5:Permits |2C operation 
0:Prohibition of operation 
1:Permission of operation 
bit4-0:F requency of a transfer clock 
00000-11111 
All other bits: 0 


Table 6.15.5 |2C dock parameter format 
(*1) For details information about |2C clock, refer to the chapter of the “clock control 
register” of “l2C Interface specification”. 
Description Reads CCR (Clock Control Register) and returns | 2C clock control status. 


This command is for MB86291S or MB86292S. 
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6.15.6 Gdcl2CSetData [Sets transfer data] 


Format 


Parameter 
Return value 


Description 


void Gdcl 2CSetData (GDC_UCHAR param) 


param Value of transfer data 

None 

Writes value of transfer data to DAR (DAta Register). 
This command is for MB86291S or MB86292S. 


6.15.7 Gdcl2CGetData [Gets transfer data] 


Format 


Parameter 
Return value 


Description 


GDC_ULONG Gdd 2CGetData (void) 


None 

Value of transfer data 

Reads DAR (DAta Register) and returns value of transfer data. 
This command is for MB86291S or MB86292S. 
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7 System dependent Commands 


This section describes which the “Graphics Controller” a system dependence command can be 
used with it. It is necessary for a graphics application developer to make these. 


7.1 System Dependent Commands 


System dependent commands list is shown in the table 7.1. 


Table 7.1 System dependent commands list 


No. Command name Function 
1_| GdcSetDisplayListBuffer Sets Display List buffer 
2 | GdcFlushDisplayList Transfers a Display List 
3 | GdcGetHostRegisterAddress Gets host interface register area address 
4 | GdcGetDispRegisterAddress Gets display control register area address 
5 | GdcGetDrawRegisterAddress Gets drawing control register area address 
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8 System dependent Commands Interface 


This section describes calling conventions interface and processing contents of a system 


dependent command. 


8.1 Explanatory notes 


Each item of a driver command reference seems to become following. 


Format Prototype declaration of a command. 
Parameter Description of a parameter. 

Return value Thereturn value and the description. 
Called by The command name of a calling origin. 


Description Description of the command. 
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8.2 Command Interface 


8.2.1. GdcSetDisplayListBuffer [Sets Display List buffer] 


Format 


Parameter 


Return value 


Called by 


Description 


int GdcSetDisplayListBuffer (GDC_ULONG **base, GDC_ULONG *total_size, 
GDC_ULONG *num) 


base Pointer to get the start address of the Display List buffer field 
total_size Pointer to get the size of the Display List buffer field 
num Pointer to get the block count of the Display List buffer field 


Effective values are 1 or 2 
GDC_TRUE Complete 
GDC_FALSE Incomplete 
Gdecl nitialize command 
This command sets the Display List buffer information, such as the start address, size 
and block configuration of the Display List buffer field acquired by the application 
program, to the “Graphics Driver” through respective pointers. The start address, 
size (total byte count) and number of blocks must be set to the area which are pointed 
by the parameters, base, total_size and num respectively. The start address of the 
Display List buffer needs to be the host CPU address, even though the MB86290 
series controls the data transfer. 1 (1 block) or 2 (2 blocks) is applied as a number of 
blocks. 


[1 block configuration] 

In 1 block configuration, the “Graphics Driver” uses the entire Display List buffer 
area as 1 block. In 1 block configuration, when a Display List transfer is started, 
driver command waits for the end of this transfer and then returns to the application. 
This means the execution time of each command depends on whether or not Display 


List transfers occur. 


[2 blocks configuration] 

In 2 blocks configuration, the entire Display List buffer area is divided into 2 equal 
blocks and these 2 blocks are used exclusively. When 1 block is fully filled with 
Display List information, transfer of that Display List is started and continuous part 
of the Display List is filled into the other block. |n 2 blocks configuration, by using 
DMA function or master function of the “Graphics Controller”, the “Graphics Driver” 


does not need to check the completion of Display List transfer by itself. 
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Example 


[Error manipulation] 
If this command fails to acquire the Display List buffer area, sets GDC FALSE tothe 
return value. In this case, the Gddl nitialize command ends as initialization failure 


(GDC_FALSE). 


[Remark] 


- The size of Display List buffer must bea multiple of 32byte. 


This command can be used by all “Graphics Controller”. 
#define BUF_NUM 2 
#define BUF_SIZE ((2*256*256+32)*BUF_NUM) 


int GdcSetDisplayListBuffer(GDC_ULONG **base, GDC_ULONG #*total_size, 
GDC_ULONG *num){ 

/* Acquisition of Display List buffer area */ 

/* A malloc function is a library function of ANSI regulation. 


In this driver, since it does not provide, prepares according to the environment 


of use. */ 
if( (‘base =(GDC_ULONG *)malloc(BUF_SIZE)) NULL ) 
return(GDC_FALSE); /* Acquisition failure */ 


*total_size =BUF_SIZE; 
*num =BUF_NUM; 
return(GDC_TRUE); /* Acquisition complete */ 
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8.2.2. GdcFlushDisplayList [Transfers a Display List] 


Format 


Parameter 


Return value 


Called by 


Description 


void GdcFlushDisplayList (GDC_ULONG *src, GDC_ULONG count) 


src Source address (Display List buffer) 
count Transfer count 
None 


GdcF lush, GdcVFlush command 
All drawing commands 
This command is to transfer a Display List of the size specified by “count” started 
from the source address specified by “src”. The “src” specifies the Display List buffer 
address mapped to the host CPU address field. The unit of “count” is what specified 
by the GdcSetDMAMode command (32byte or 4byte). If the GdcSetDM AMode 
command is not applied since DMA is not used, this unit is set to 4 byte. For the 
Display List transfer, the following three methods are applicable. For each procedure, 
refer to the description [Display List transfer procedure] as follows: 

- DMA transfer 

- Transfer of Local Display List 

- CPU transfer 


This command can be used by all “Graphics Controller”. 
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[Display List transfer procedure] 
* DMA transfer 
This is a method of Display List transfers utilizing the DMA controller of the host CPU (the 
“Graphics Controller” does not contain a DMA controller). The operation procedure of this case is 
shown as follows. Prior to call this command, DMA transfer mode must be appropriately set on 
both DMAC (the host CPU) and the “Graphics Controller”. 
(1) Checks DMA transfer enable/disable 
- Checks the appropriate operation mode check of the DMAC and wait till it will be 
ready to accept a new DMA transaction request. 
(2) Sets DMA (According to the applied procedure for the DMAC, set the following parameter) 
- Source address (the address specified in “src”). 
- Destination address (Display List FIFO of the “Graphics Controller”). 
- Transfer count (the value specified in “count”). 
(3) Sets transfer count (the MB86290 Series side) 
- Sets DMA transfer count (the value specified in “count”) to DTC (DMA Transfer 
Count) register. 
(4) Starts DMA transaction 
- Appropriate start up operation for the applied DMA controller. 
(5) Issues the DMA request 
- Sets 1 to DRQ (DMA ReQuest) register. 
(6) Waits for the completion of the DMA transfer 
- 1 block configuration Display List buffer is applied, wait till the end of DMA 


transaction. 


[Remark] 
When the unit of transfer count is 32byte, if the total byte size of the Display List is not a 
multiple of 32byte, the driver command fills appropriate number of NOP and makes the size to be 


a multiple of 32byte. 
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[Example] 
/* Start address of the host interface register field */ 
/* Please set a suitable value to the following ##44HHHH 
according to the environment of use*/ 
#define HOSTBASE 0x74#H4HHH+4 


/* Start address of drawing control register field */ 
/* Please set a suitable value to the following ##44HHHH 
according to the environment of use*/ 


#define DRAWBASE Ox7HHHHAHEE 
#define WRITE_DTC(i) ( *(GDC_ULONG*)(HOSTBASE +0x00) =(i) ) 
#define WRITE_DRQ(i) (*(GDC_ULONG*)(HOSTBASE +0x18) =(i) ) 


ifdef GDC_MB86290A 

#define FIFO ADDRESS (DRAWBASE +0x4a0) /* for MB86290A */ 

#else 

#define FIFO_ADDRESS (DRAWBASE +0x8400) /* for MB86291 or later */ 
#endif 


void GdcF lushDisplayList(GDC_ULONG *src, GDC_ULONG count){ 
/* Polling for DMA ready DMA */ 
/* Please create DMA_BUSY function according to the environment of use */ 
while( DMA_BUSY () ); 


/* Sets transfer count */ 
/* Please create SET_DMA_COUNT function according to the environment of use */ 
SET_DMA_COUNT(CHANNELO, count); 


/* Sets source address */ 
/* Please create SET_DMA_SRC function according to the environment of use */ 
SET_DMA_SRC(CHANNELO, src); 


/* Sets destination address */ 
/* Please create SET_DMA_DEST function according to the environment of use */ 
SET_DMA_DEST(CHANNELO, FIFO_ADDRESS); 


/* Sets transfer count (Graphics Controller) */ 
WRITE_DTC(count); 


/* Trigger of DMA transaction */ 
/* Please create DMA_START function according to the environment of use */ 
DMA_START(); 


/* |ssue of external DMA request */ 
WRITE_DRQ(1); 


#fdef SINGLE_DL_BUFFER 
/* Wait for the next Display List buffer write to be ready */ 
while( DMA_BUSY() ); 

#endif 

if 
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*Transfer of Local Display List 
This is a method of the Display List transfers utilizing the bus master function of the “Graphics 
Controller”. Transfer count is 4byte unit. In this case, the Display List buffer must be located to 
the graphics memory of the “Graphics Controller”. And the source address “src” must be converted 
to the local address of the “Graphics Controller”. The operation procedure of this case is shown as 
follows: 
(1) Checks transfer enable/disable 
- Checks the status of LSTA (display List transfer STAtus) register and wait until it 
will be 0. 
(2) Sets source address 
- Sets the source address to LSA (display List Source Address) register. The address to 
be set to this register is 
(“src” value) - (start address of host interface register field) 
(3) Sets transfer count 
- Sets the transfer count (“count” value) to LCO (display List COunt) register. 
(4) Starts the transaction 
- Sets 1 to LREQ (display List transfer RE Quest) register. 
(5) Waits for the completion of the transfer (in case of single DL buffer mode) 
- Same as (1). 


[Example] 
/* Start address of host interface register field */ 
/* Please set a suitable value to the following ##44HHHH 
according to the environment of use*/ 
#define HOSTBASE Ox 7HHHHHHEE 


/* Start address of graphics memory field */ 

/* Please set a suitable value to the following ##4444Ht 
according to the environment of use*/ 

#define MB86290 BASE Ox 7HHHHHHEE 


#define READ_LSTA() *((volatile GDC_ULONG*)(HOST BASE +40x10)) 
#define WRITE_LSA(i) ( *((GDC_ULONG*)(HOSTBASE +0x40)) =(i) ) 
#define WRITE_LCO(i) ( *((GDC_ULONG*)(HOST BASE 40x44)) =(i) ) 
#define WRITE_LREQ(i) ( *((GDC_ULONG*)(HOSTBASE +0x48)) =(i) ) 


void GdcF lushDisplayList(GDC_ULONG *src, GDC_ULONG count){ 
GDC_ULONG src_local; 


/* Polling of transfer ready */ 
while( READ_LSTA\() ); 


/* Source address set */ 
src_local =(GDC_ULONG)src - MB86290_ BASE; 
WRITE_LSA(src local); 


/* Transfer count set */ 
WRITE_LCO(count); 


/* Trigger */ 
WRITE_LREQ(1); 


#ifdef SINGLE_DL_BUFFER 
/* Wait for next the Display List buffer write to be ready */ 
while( READ_LSTA\() ); 

#endif 

} 
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*CPU transfer 
This is a method to write the transfer data (Display List) to the Display List FIFO of MB86290 
Series by software. The operation procedure of this caseis shown as follows. Repeat (1) 
through (4) for the times specified by “count”. 
(1) Acquires the Display List FIFO status 
- Calls the GdcGetF | F OStatus command and acquire the Display List FIFO status 
information. 
(2) Checks the Display List FIFO status 
- Checks the empty entries of the Display List FIFO from the above status information. 
If FIFO is full, keep repeating (1) and (2) till open entries will be available. 
(3) Transfers 4byte of data from the source address to the Display List FIFO 


(4) Posts increment (+4) source address 


[Example] 
/* Start address of drawing control register field */ 
/* Please set a suitable value to the following ##4#44HHH+ 
according to the environment of use*/ 
#define DRAWBASE Ox#HHHHHHHE 
#define FIFO FULL Ox2 


#fdef GDC_MB86290A 
/* for MB86290A */ 


#define WRITE_FIFO(i) ( *(volatile GDC_ULONG*)(DRAWBASE +40x4a0) = (i) ) 
Helse 

/* for MB86291 or later */ 

#define WRITE_FIFO(i) ( *(volatile GDC_ULONG*)(DRAWBASE 40x8400) =(i) ) 
Hendif 


void GdcF lushDisplayList(GDC_ULONG *src, GDC_ULONG count){ 
int i; 


for(i =0; i <count; i+4{ 
/* If FIFO is full, wait until open entry will be available */ 
while(GdcGetF IF OStatus() & FIFO_FULL); 


/* Transfers data to the FIFO */ 
WRITE_FIFO(*src-+4); 
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8.2.3 GdcGetHostRegisterAddress [Gets host interface register area address] 


Format GDC_ULONG *GdcGetHostRegisterAddress (void) 


Parameter None 

Return value — Start address of host interface register field 

Called by Gdcl nitialize command 

Description Start address of host interface register field is returned. 


This command can be used by all “Graphics Controller”. 


8.2.4 GdcGetDispRegisterAddress [Gets display control register area address] 


Format GDC_ULONG *GdcGetDispRegisterAddress (void) 


Parameter None 

Return value — Start address of display control register field 

Called by Gdcl nitialize command 

Description Start address of display control register field is returned. 


This command can be used by all “Graphics Controller”. 


8.2.5 GdcGetDrawRegisterAddress [Gets drawing control register 


address] 
Format GDC_ULONG *GdcGetDrawRegisterAddress (void) 
Parameter None 


Return value — Start address of drawing control register field 
Called by Gdcl nitialize command 
Description Start address of drawing control register field is returned. 


This command can be used by all “Graphics Controller”. 


area 
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